设为首页 收藏本站
查看: 1131|回复: 0

[经验分享] db2 隔离级别-试验

[复制链接]

尚未签到

发表于 2016-11-14 10:51:59 | 显示全部楼层 |阅读模式
准备工作
db2命令行下,执行:list command options,如图:
DSC0000.jpg

注意,Auto Commit缺省是ON,即自动提交。使用下面的命令来查看设置:

执行命令:
update command options using c off,

再执行命令:list command options,如图:
DSC0001.jpg

这时可以看到Auto Commit 已经变为OFF了

DB2使用一个叫做“CURRENT ISOLATION”的special register来记录session的隔离级别。查看当前隔离级别有两种方法:

VALUES CURRENT ISOLATION

SELECT CURRENT ISOLATION FROM SYSIBM.SYSDUMMY1

设置隔离级别命令如下(此命令不需要显式COMMIT):

SET CURRENT ISOLATION TO UR/CS/RS/RR

由于该测试需要并发事务,所以我们要用同样方法,再打开一个窗口。以下称为session1和session2。

把两个session都连接到DINGTEST数据库,并建一张表TA如下:

AC1 AC2
1    1
2    2
3    3
4    4
5    5


至此准备工作完成,我们开始实验。

注:每次实验完以后别忘记清理环境,即把session commit/rollback。

实验1
测试在“UR”隔离级别下是否会产生“丢失更新”的问题。

方法:两个session并发更新同一条记录。
STEP 0:把session1和session2都设置为UR隔离级别:
SET CURRENT ISOLATION TO UR

STEP 1:在session1中做更新操作,但不提交:
UPDATE TA SET AC2 = 2 WHERE AC1 = 1

STEP 2:在session2中对同一条记录做更新操作:
UPDATE TA SET AC2 = 3 WHERE AC1 = 1

Session2被block住……

STEP 3:在session1中做commit/rollback操作,则session2会立刻继续执行。

结论:在“UR”隔离级别下不会产生“丢失更新”的问题。

实验2
测试在“UR”隔离级别下是否会产生“读脏数据”的问题。

方法:在session2中查询session1中更改但未提交的数据。

STEP 0:把两个session都设置为UR隔离级别:
SET CURRENT ISOLATION TO UR

STEP 1:在session1中做更新操作,但不提交:
UPDATE TA SET AC2 = 4 WHERE AC1 = 1

STEP 2:在session2中查询该记录:
SELECT * FROM TA WHERE AC1 = 1

Session2中立即返回查询结果,该记录值为session1更新后的值,这实际是一个脏数据,session1有可能最终会rollback。

STEP 3:在session1中做rollback操作。

STEP 4:在session2中再次查询该记录。
SELECT * FROM TA WHERE AC1 = 1

该记录值为session1更新前的值,因为session1已经rollback了,第一次读到的是一个脏数据。

结论:在“UR”隔离级别下会产生“读脏数据”的问题

实验3
测试在“CS”隔离级别下是否会产生“读脏数据”的问题。
方法:在session2中查询session1中更改但未提交的数据。

STEP 0:把两个session都设置为CS隔离级别:
SET CURRENT ISOLATION TO CS

STEP 1:在session1中做更新操作,但不提交:
UPDATE TA SET AC2 = 5 WHERE AC1 = 1

STEP 2:在session2中查询该记录:
SELECT * FROM TA WHERE AC1 = 1

Session2被block住……

STEP 3:在session1中做commit/rollback操作,则session2会立刻继续执行。

结论:在“CS”隔离级别下不会产生“读脏数据”的问题。

实验4
测试在“CS”隔离级别下会是否会产生“不可重复读”的问题。

方法:尝试在session1的两次查询之间修改其查询的记录。

STEP 0:把两个session都设置为CS隔离级别:
SET CURRENT ISOLATION TO CS

STEP 1:在session1中做查询操作,但不提交:
SELECT * FROM TA WHERE AC1 = 1
假定查询结果中AC2为“4”。

STEP 2:在session2中更新此记录,并提交(不提交的话,session1就无法再查询该记录了):
UPDATE TA SET AC2 = 5 WHERE AC1 = 1
COMMIT

STEP 3:在session1中再次查询该记录:
SELECT * FROM TA WHERE AC1 = 1
这次查询结果中,AC2为“5”。这就产生了在同一个事务中,两次查询的数据不一致的问题。


结论:在“CS”隔离级别下会产生“不可重复读”的问题

实验5
测试在“RS”隔离级别下是否会产生“不可重复读”的问题。
方法:尝试在session1的两次查询之间修改其查询的记录。

STEP 0:把两个session都设置为RS隔离级别:
SET CURRENT ISOLATION TO RS

STEP 1:在session1中做查询操作,但不提交:
SELECT * FROM TA WHERE AC1 = 1
假定查询结果中AC2为5

STEP 2:在session2中更新此记录:
UPDATE TA SET AC2 = 6 WHERE AC1 = 1

Session2被block住……

STEP 3:在session1中再次查询该记录:
SELECT * FROM TA WHERE AC1 = 1

这次查询结果中,AC2仍然为5。这表明在RS隔离级别下,在事务中,查询的记录都被lock住了,以保证同一事务中,多次查询的数据都一致。

STEP 4:在session1中做commit/rollback操作,则session2立即继续执行。

结论:在“RS”隔离级别下不会产生“不可重复读”的问题。

实验6
测试在“RS”隔离级别下是否会产生“幻象记录”的问题。
方法:尝试在session1的两次查询之间添加符合其查询条件的记录。

STEP 0:把两个session都设置为RS隔离级别:
SET CURRENT ISOLATION TO RS

STEP 1:在session1中做查询操作,但不提交:
SELECT * FROM TA WHERE AC1 > 0 AND AC1 < 10
假定查询结果有5条记录。

STEP 2:在session2中INSERT一条记录,并提交:
INSERT INTO TA (AC1, AC2) VALUES (6, 1)
COMMIT

STEP 3:在session1中做同样的查询操作:
SELECT * FROM TA WHERE AC1 > 0 AND AC1 < 10

这次查询结果中,变成了6条记录。这就产生了在同一个事务中,两次查询的数据不一致的问题。虽然第一次查到的记录都被lock住了不会被改变,但若在两次查询之间,其它session若新插入了记录,则在第二次查询中也会被查到。该记录被称为幻象(phantom)记录。

结论:在“RS”隔离级别下会产生“幻象记录”的问题

实验7
测试在“RR”隔离级别下是否会产生“幻象记录”的问题。
方法:尝试在session1的两次查询之间添加符合其查询条件的记录。

STEP 0:把两个session都设置为RR隔离级别:
SET CURRENT ISOLATION TO RR

STEP 1:在session1中做查询操作,但不提交:
SELECT * FROM TA WHERE AC1 > 0 AND AC1 < 10
假定查询结果有6条记录。

STEP 2:在session2中INSERT一条记录:
INSERT INTO TA (AC1, AC2) VALUES (7, 1)

Session2被block住了……

STEP 3:在session1中做同样的查询操作:
SELECT * FROM TA WHERE AC1 > 0 AND AC1 < 10
查询结果仍为6条记录,且数据和第一次查询保持一致。

STEP 4:在session1中做commit/rollback操作

则session2立即继续执行。

结论:在“RR”隔离级别下不会产生“幻象记录”的问题。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-300203-1-1.html 上篇帖子: DB2之OLAP函数 下篇帖子: DB2常用函数总结
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表