不可重复读和幻读的有什么区别,感觉非常类似阿 谁能讲讲,谢谢 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 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中插入新的数据,从而避免了幻读!一点个人见解,希望下面的高手再做补充! 編程王10TB代碼庫http://code.kingofcoders.com10TB代碼Search enginehttp://search.kingofcoders.com編程王10TB代碼庫http://code.kingofcoders.com10TB代碼Search enginehttp://search.kingofcoders.com編程王10TB代碼庫http://code.kingofcoders.com10TB代碼Search enginehttp://search.kingofcoders.com編程王10TB代碼庫http://code.kingofcoders.com10TB代碼Search enginehttp://search.kingofcoders.com編程王10TB代碼庫http://code.kingofcoders.com10TB代碼Search enginehttp://search.kingofcoders.com編程王10TB代碼庫http://code.kingofcoders.com10TB代碼Search enginehttp://search.kingofcoders.com編程王10TB代碼庫http://code.kingofcoders.com10TB代碼Search enginehttp://search.kingofcoders.com編程王10TB代碼庫http://code.kingofcoders.com10TB代碼Search enginehttp://search.kingofcoders.com編程王10TB代碼庫http://code.kingofcoders.com10TB代碼Search enginehttp://search.kingofcoders.com編程王10TB代碼庫http://code.kingofcoders.com10TB代碼Search enginehttp://search.kingofcoders.com編程王10TB代碼庫http://code.kingofcoders.com10TB代碼Search enginehttp://search.kingofcoders.com編程王10TB代碼庫http://code.kingofcoders.com10TB代碼Search enginehttp://search.kingofcoders.com編程王10TB代碼庫http://code.kingofcoders.com10TB代碼Search enginehttp://search.kingofcoders.com 对机试成绩反复加分,出问题啦 - 求解!感激不尽 有什么方法把两个结构相同的表的不同的记录找出来? 求一教程,100分相谢 我的数据库被攻击了 这个是补给 libin_ftsafe(子陌红尘) 的 400 分的帖子(4/4) 关于百分比区间的统计 sql问题 请教各位一个远程连接的问题 ORACLE数据库怎么导入导出数据? 怎么通过文件让一台机上的数据库导入到另一台机上的数据库? 做主键用int增长好,还是用uniqueident(newid())好 请问如何判断需要使用复合索引还是为每个列单独建立索引?
还是上面的例子,事务A要两次读取表T的中数据,虽然设置 repeatable read 可以防止事务B对数据进行修改,但是事务B却可以向表T中插入新的数据。如何防止这个问题,我们可以考虑设置最高的事务隔离级别 set tran isolation level serializable。于是乎,事务B就只能乖乖的等待事务A的提交,才能想表T中插入新的数据,从而避免了幻读!
一点个人见解,希望下面的高手再做补充!
http://code.kingofcoders.com10TB代碼Search engine
http://search.kingofcoders.com編程王10TB代碼庫
http://code.kingofcoders.com10TB代碼Search engine
http://search.kingofcoders.com編程王10TB代碼庫
http://code.kingofcoders.com10TB代碼Search engine
http://search.kingofcoders.com編程王10TB代碼庫
http://code.kingofcoders.com10TB代碼Search engine
http://search.kingofcoders.com編程王10TB代碼庫
http://code.kingofcoders.com10TB代碼Search engine
http://search.kingofcoders.com編程王10TB代碼庫
http://code.kingofcoders.com10TB代碼Search engine
http://search.kingofcoders.com編程王10TB代碼庫
http://code.kingofcoders.com10TB代碼Search engine
http://search.kingofcoders.com編程王10TB代碼庫
http://code.kingofcoders.com10TB代碼Search engine
http://search.kingofcoders.com編程王10TB代碼庫
http://code.kingofcoders.com10TB代碼Search engine
http://search.kingofcoders.com編程王10TB代碼庫
http://code.kingofcoders.com10TB代碼Search engine
http://search.kingofcoders.com編程王10TB代碼庫
http://code.kingofcoders.com10TB代碼Search engine
http://search.kingofcoders.com編程王10TB代碼庫
http://code.kingofcoders.com10TB代碼Search engine
http://search.kingofcoders.com編程王10TB代碼庫
http://code.kingofcoders.com10TB代碼Search engine
http://search.kingofcoders.com