consistent mode与current mode :
consistent mode 是在基于query mode 下的,当查询开始的时候oracle将确立一个时间点,
凡是在这个时间点以前提交的数据oracle将能看见,之后提交的数据将不能看见。但查询的时
候可能遇上这样的情况,该块中数据已经被修改了,没有提交,或者提交的时间点比查询开始
的时间晚,则oracle为了保证 读的一致性,需要去回滚段获取 该块中变化前的数据(before
image)。这叫 consistent reads 。
current mode 当看到当前的block中的内容的时候,是什么就是什么,跟时间点无关,不用
去回滚段获取之前的数据。什么时候会是这样的模式? 除了9i以前版本的FTS对数据字典的获取
是current mode外(这是因为关于数据字典的获取必须是当前看见的状态),主要就是发生在DML
的时候,当发生DML的时候,session所看见的必须是当前的block的状态,不能去回滚段获取数据
(否则就乱套了)。假如当前block中数据是被session更改过还没有提交,那么看当前状态数据则
被其他session 锁定,出现等待 (这才是正常的)。(查询去回滚段获取数据,读和更新之间不会
出现锁的情况)
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/35489/viewspace-760088/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/35489/viewspace-760088/