DB2事务隔离级别

DB2中基本的锁有两类:
共享锁(Share locks简记为S锁):也称读锁,事务A对对象T加S锁,其他事务也只能对T加S,多个事务可以同时读,但不能有写操作,直到A释放S锁。
排它锁(Exclusivelocks简记为X锁):也称写锁,事务A对对象T加X锁以后,其他事务不能对T加任何锁,只有事务A可以读写对象T直到A释放X锁。

事务隔离级别:

隔离级别脏读不可重复读幻读
未提交读(Uncommitted Read)
游标稳定性(Cursor Stability)
读稳定性(Read Stability)
可重复读(Repeatable Read)

1、UR(Uncommited Read)  :“脏读“,在没有提交数据的时候能够读到更新的数据;
2、CS(Cursor Stability) :为DB2缺省的隔离级别,只对目前正读取的行加锁,一旦读完就释放,然后获取下一行的锁,目的是为了得到一个平稳读;
3、RS(Read Stability) :不像CS,它不仅仅给目前正在读取的行加锁,而且给整个结果集加锁,这可以保证在相同的事务内,已经被读取的行不会被其他应用更改;
4、RR(Repeatable Read):它除了锁查询的结果集外,还给为了获取结果集而读取的任何记录行,这保证了在事务期间,你得查询每次重复可以得到一样的结果集;
 

在DB2中,共有四种隔离级:RS,RR,CS,UR.以下对四种隔离级进行一些描述,同时附上个人做试验的结果。隔离级是影响加锁策略的重要环节,它直接影响加锁的范围及锁的持续时间。两个应用程序即使执行的相同的操作,也可能由于选择的隔离级的不同而造成加锁的结果不同。

  在DB2中,共有四种隔离级:RS,RR,CS,UR.以下对四种隔离级进行一些描述。

读可靠性(RS-Read Stability)
  如果使用这种隔离级,在一个事务中所有被读取过的行上都会被加上NS锁,直到该事务被提交或回滚,行上的锁才会被释放。这样可以保证在一个事务中即使多次读取同一行,得到的值不会改变。

  但其他事务可以插入,可以防止db2定义的不可重复读,但有幻读问题。即如果使用这种隔离级,在一个事务中,如果使用同样的搜索标准重新打开已被处理过的游标,则结果集可能改变。(可能会增加某些行,这些行被称为幻影行(Phantom))。这是因为RS隔离级不能阻止通过插入或更新操作在结果集中加入新行。

  个人笔记:

   根据实际测试情况,RS模式下:查询完毕以后,满足条件的结果集中的记录被锁定,不满足条件的不被锁定。

   可以对不满足条件的记录更新,也可以插入新的记录。其他人可以查询满足已经锁定的记录,但不可以更新。

重复读(RR-Repeat Read)
  如果使用这种隔离级,在一个事务中所有被读取过的行上都会被加上S锁,知道该事务被提交或回滚,行上的锁才会被释放。这样可以保证在一个事务中即使多次读取同一行,得到的值不会改变。

  另外,在同一事务中如果以同样的搜索标准重新打开已被处理过的游标,得到的结果集不会改变。重复读相对于读可靠性而言,加锁的范围更大。

  解决幻读。锁定读事务以任何方式引用的所有行,整个表加S锁。相当于serializable读写用锁互斥  

  对于读可靠性,应用程序只对符合要求的所有行加锁,而对于重复读,应用程序将对所有被扫描过的行都加锁。例如,如果一个应用程序对一个表中的 10000行数据进行扫描,最终找到了100条符合搜索条件的结果行。如果该应用程序使用的是读可靠性隔离级,应用程序将只对这符合条件的100行加锁;如果该应用程序使用的是重复读隔离级,应用程序将对被扫描过的10000行都加锁。

  个人笔记

   根据实际测试情况,RR模式下:查询完毕以后,不可以对不满足条件的进行更新,也不可以插入新记录。可能原因是:如果允许别人更新记录或者插入新记录的话,则可能造成原来结果集的破坏,重新读的时候和以前不同。

   select for update with rr/rs 是可以用来实现记录锁。是一种特殊情况。即便是RR,仍然可以对其他记录操作。

游标可靠性(CS-Cursor Stability)
  如果使用这种隔离级,在一个事务中,结果集中只有正在被读取的那一行(游标指向的行)将被加上NS锁,其他未被处理的行上不被加锁。这种隔离级只能保证正在被处理的行的值不会被其他并发的程序所改变。该隔离级是DB2缺省的隔离级。防止脏读。其他事务不能更新/删除游标当前所引用的行。可能出现db2定义的不可重复读和幻读。

  个人笔记

  仅仅在游标在该行的时候锁定,这是一种非常弱的隔离状态。

未提交读(UR-Uncommitted Read)
  如果使用这种隔离级,对于只读操作,不加行锁。典型的只读操作包括:

   SELECT语句的结果集只读(比如语句中包括ORDER BY子句);

  定义游标是指明起为FOR FETCH ONLY。

  该隔离级可以改善应用程序的性能,同时可以最大程度的允许并发。但是,应用程序的数据完整性将受到威胁。如果需要读取未提交的数据,该隔离级是唯一选择。

  个人笔记

  读的时候完全不受限制,对于同一行记录的完整性也无法保证。

  总结

  以上我们所提的隔离级的加锁范围和持续时间都是针对于读操作而言的。

  对于更改操作,被修改的行上会被加上X锁,不论使用何种隔离级,X锁直到提交或回滚之后才会被释放。

参考地址:

DB2并发控制-事务隔离级别_ITPUB博客

http://blog.csdn.net/msoso_______1988/article/details/9248535

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值