DB2隔离级的解读与对其结果的试验

数据库
以下文章主要是介绍DB2隔离级的解读和试验,以下是文章对DB2隔离级的解读和试验的具体介绍,望你浏览完以下的内容会有所收获。

此文章主要向大家描述的是DB2隔离级的解读和试验,如果你对DB2隔离级的解读和试验心存好奇的话,你就可以点击以下的文章进行观看了,以下就是文章的详细内容介绍,望大家借鉴。

 

在DB2中,共有四种隔离级:RS,RR,CS,UR.以下对四种隔离级进行一些描述,同时附上个人做试验的结果。隔离级是影响加锁策略的重要环节,它直接影响加锁的范围及锁的持续时间。

 

基本信息

 

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

隔离级解读和试验

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

读可靠性(RS-Read Stability)

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

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

个人笔记:

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

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

重复读(RR-Repeat Read)

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

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

对于读可靠性,应用程序只对符合要求的所有行加锁,而对于重复读,应用程序将对所有被扫描过的行都加锁。例如,如果一个应用程序对一个表中的 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锁,不论使用何种DB2隔离级,X锁直到提交或回滚之后才会被释放。

【编辑推荐】

  1.  如何避免DB2性能理解的20大误区?
  2. IBM DB2 9只毒蛇这样“毒”的原因是什么
  3. DB2 9 分布式管理之维护的描述
  4. DB2 V7存储过程构建环境的正确设置步骤
  5. DB2管理页大小的一些限制条件有哪些?

 

责任编辑:佚名 来源: 网络整理
相关推荐

2010-07-29 10:30:41

DB2隔离级

2010-08-06 14:08:44

DB2隔离级解读

2010-07-28 14:16:43

DB2驱动类型

2010-08-04 13:51:05

2010-09-30 16:41:36

DB2隔离级别

2010-08-26 10:13:52

DB2java连接

2010-09-01 11:17:29

DB2备份

2010-08-04 17:33:39

DB2数据库

2010-08-02 17:30:30

DB2锁等待

2010-11-03 10:35:45

DB2存储过程

2010-08-05 09:14:29

DB2隔离级别

2010-09-30 16:21:40

DB2隔离级别

2010-08-17 10:06:25

IBM DB2的数据复

2010-08-06 13:20:00

DB2锁等待

2010-08-02 14:03:49

DB2驱动类型

2010-07-27 15:02:30

DB2驱动类型

2010-08-06 14:52:13

DB2 9.7武器

2010-07-27 10:32:22

DB2数据库编目

2010-08-03 11:33:30

DB2并置

2010-08-25 14:46:53

DB2PostgreSQL开发
点赞
收藏

51CTO技术栈公众号