oracle redo与undo_笔记2:INSERT语句
INSERT
对于第一条INSERT INTO T语句,redo和undo都会生成。所生成的undo信息足以使INSERT“消失”。INSERT INTO T生成的redo信息则足以让这个插入“再次发生”。
假想场景:系统现在崩溃
即使系统现在崩溃也没关系。SGA会被清空,但是我们并不需要SGA里的任何内容。重启动时就好像这个事务从来没有发生过一样。没有将任何已修改的块刷新输出到磁盘,也没有任何redo刷新输出到磁盘。不需要这些undo或redo信息来实现实例失败恢复。
假想场景:缓冲区缓存现在已满
在这种情况下,DBWR必须留出空间,要把已修改的块从缓存刷新输出。如果是这样,DBWR首先要求LGWR将保护这些数据库块的redo条目刷新输出。DBWR将任何有修改的块写至磁盘之前,LGWR必须先刷新输出与这些块相关的redo信息。这是有道理的——如果我们要刷新输出表T中已修改的块,但没有刷新输出与undo块关联的redo条目,倘若系统失败了,此时就会有一个已修改的表T块,而没有与之相关的redo信息。在写出这些块之前需要先刷新输出重做日志缓冲区,这样就能重做所有必要的修改,将SGA放回到现在的状态,从而能发生回滚。
本文来源 我爱IT技术网 http://www.52ij.com/jishu/5252.html 转载请保留链接。
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
