幻读和不成反复读区别
幻读和不成反复读的不同
1) "不成反复读" 是指在一个事务内,屡次读统一数据。在这个事务还没有完毕时,别的一个事务也拜访该统一数据。那么,在第一个事务中的两次读数据之间,由于第二个事务的修改,那么第一个事务两次读到的的数据大概是不一样的。这样就发生了在一个事务内两次读到的数据是不一样的,因此称为是不成反复读。
例如,一个编纂人员两次读取统一文档,但在两次读取之间,作者重写了该文档。当编纂人员第二次读取文档时,文档已更换。原始读取不成反复。假如只要在作者全部完成编写后编纂人员才可以读取文档,则可以幸免该问题
要幸免这种状况,平常可以用 set tran isolation level repeatable read 来设定隔离级别,这样事务A 在两次读取表T中的数据时,事务B假如妄想更换表T中的数据(细节到事务A读取数据)时,就会被堵塞,知道事务A提交! 这样就包管了,事务A两次读取的数据的一致性。
2)幻读是指当事务不是独立施行时发生的一种现象,例如第一个事务对一个表中的数据停止了修改,这种修改触及到表中的全部数据行。同时,第二个事务也修改这个表中的数据,这种修改是向表中插入一行新数据。
那么,今后就会发生操纵第一个事务的会员发明表中还有没有修改的数据行,就仿佛发生了幻觉一样。
例如,一个编纂人员更换作者提交的文档,但当生产部门将其更换内容合并到该文档的主复本时,发明作者已将未编纂的新材料增加到该文档中。假如在编纂人员和生产部门完成对原始文档的处置此前,任何人都不克不及将新材料增加到文档中,则可以幸免该问题。
还是上面的例子,事务A要两次读取表T的中数据,虽然设定 repeatable read 可以防止事务B对数据停止修改,但是事务B却可以向表T中插入新的数据。
怎样防止这个问题,我们可以思考设定最高的事务隔离级别 set tran isolation level serializable。于是乎,事务B就只能乖乖的等候事务A的提交,才能想表T中插入新的数据,从而幸免了幻读!
以上就是幻读和不成反复读不同的具体内容,更多请关注百分百源码网其它相关文章!