db2隔离级别

隔离级别定义用于控制并发事务的行为,它决定在访问数据时数据是如何锁定的、如何与其他进程隔离的。

包括四个级别,级别从高到低:

RR(可重复读取)

RS(读取稳定性)

CS(游标稳定性)

UR(未提交的读取)

1.RR隔离级别:在此隔离级别下, DB2会锁住所有相关的纪录。 在一个SQL语句执行期间, 所有执行此语句扫描过的纪录都会被加上相应的锁。在一个SQL语句执行期间,所有执行此语句扫描过的纪录都会被加上相应的锁。 具体的锁的类型还是由操作的类型来决定, 如果是读取,则加共享锁; 如果是更新, 则加独占锁。具体的锁的类型还是由操作的类型来决定,如果是读取,则加共享锁;如果是更新,则加独占锁。 由于会锁定所有为获得SQL语句的结果而扫描的纪录, 所以锁的数量可能会很庞大, 这个时候, 索引的增加可能会对SQL语句的执行有很大的影响,因为索引会影响SQL语句扫描的纪录数量。由於会锁定所有為获得SQL语句的结果而扫描的纪录,所以锁 的数量可能会很庞大,这个时候,索引的增加可能会对SQL语句的执行有很大的影响,因為索引会影响SQL语句扫描的纪录数量。 

2.RS隔离级别:此隔离级别的要求比RR隔离级别稍弱,此隔离级别下会锁定所有符合条件的纪录。 不论是读取, 还是更新, 如果SQL语句中包含查询条件, 则会对所有符合条件的纪录加相应的锁。不论是读取,还是更新,如果SQL语句中包含查询条件,则会对所有符合条件的纪录加相应的锁。 如果没有条件语句, 也就是对表中的所有记录进行处理,则会对所有的纪录加锁。如果没有条件语句,也就是对錶中的所有记录进行处理,则会对所有的纪录加锁。

3.CS隔离级别:此隔离级别仅锁住当前处理的纪录。

4.UR隔离级别:此隔离级别下,如果是读取操作,不会出现任何的行级锁。 对于非只读的操作,它的锁处理和CS相同。对於非只读的操作,它的锁处理和CS相同。DB2默认的隔离级别是CS。 DB2默认的隔离级别是CS。 即游标稳定性。即游标稳定性。

Mysql为:

Read uncommitted
Read committed //当前读加锁
Repeatable read //其他事务不能插入新记录,解决幻读
Serializable //所有读均为当前读,读写互斥。

DB2:

注意:mysql和db2对幻读的定义不同,DB2中定义为:

non-repeatable read:重读数据减少:

幻读:重读数据增多


Repeatable read:   //解决幻读。锁定读事务以任何方式引用的所有行,整个表加S锁。相当于serializable读写用锁互斥 
Read stability  //read committed。锁定事务实际检索和修改的行。但其他事务可以插入。可以防止db2定义的不可重复读,但有幻读问题。
Cursor stability //防止脏读。其他事务不能更新/删除游标当前所引用的行。可能出现db2定义的不可重复读和幻读
Uncommitted read

 

总结:

两大问题:幻读(db2定义的不可重复读和幻读其实都是幻读范畴)、脏读

1.如何解读幻读?

mysql细分出两种隔离级别:repeatable read和serializable。而db2在此问题上只有一种隔离级别repeatable read。

2.如何解决脏读?

mysql分出一种隔离级别:read committed,而db2分出两种隔离级别:read stability和cursor stability.

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值