db2 get db cfg|find "CUR_COMMIT"
当前已落实                                   (CUR_COMMIT) = ON

db2 update db cfg using cur_commit off
DB20000I  UPDATE DATABASE CONFIGURATION 命令成功完成。

SQL1363W  未动态更改为立即修改而提交的一个或多个参数。对于这些配置参数,必须在所

有应用程序都与此数据库断开连接之后,更改才会生效。

db2 get db cfg|find "CUR_COMMIT"
当前已落实                                   (CUR_COMMIT) = DISABLED

C:\Users\Administrator>db2 force application all
DB20000I  FORCE APPLICATION 命令成功完成。
DB21024I  此命令为异步的,可能未能立即生效。

---session 1 从tab2表中删除一条记录
C:\Users\Administrator>db2 +c "delete from javan.tab2 where id=3"
DB20000I  SQL 命令成功完成。

C:\Users\Administrator>

---session 2 从tab2表中查 刚才删除的那条记录 会一直等待 知道锁定超时时间到

C:\Users\Administrator>db2 +c "select count(*) from javan.tab2"
SQL0911N  因为死锁或超时,所以当前事务已回滚。原因码为 "68"。  SQLSTATE=40001

C:\Users\Administrator>db2pd -db testdb -locks

Database Partition 0 -- Database TESTDB -- Active -- Up 0 days 00:07:59

Locks:
Address    TranHdl    Lockname                   Type       Mode Sts Owner
Dur HoldCount  Att        ReleaseFlg rrIID
0x7FB71E80 2          02000800060000000000000052 Row        ..X  G   2        ----------看这里对那条记录id=3 的行 加了row 行级x 排他锁 和s锁是排斥的所以session 2查这条记录 会等待直到超时
1   0          0x00000020 0x40000000 0
0x7FB72380 2          41414141415A425A7F4760B841 Internal P ..S  G   2
1   0          0x00000000 0x40000000 0
0x7FB72300 2          02000800000000000000000054 Table      .IX  G   2
1   0          0x00002000 0x40000000 0

现在我们启用db2 v9.7版本的 未提交读特性

db2 update db cfg using cur_commit on
DB20000I  UPDATE DATABASE CONFIGURATION 命令成功完成。
SQL1363W  未动态更改为立即修改而提交的一个或多个参数。对于这些配置参数,必须在所有应用程序都与此数据库断开连接之后,更改才会生效。

C:\Users\Administrator>db2 get db cfg |find "CUR_COMMIT"
当前已落实                                   (CUR_COMMIT) = ON

C:\Users\Administrator>

C:\Users\Administrator>db2 connect to testdb

数据库连接信息

数据库服务器         = DB2/NT 9.7.1
SQL 授权标识         = ADMINIST...
本地数据库别名       = TESTDB

C:\Users\Administrator>db2 get db cfg|find "CUR_COMMIT"
当前已落实                                   (CUR_COMMIT) = ON

C:\Users\Administrator>

---session 1 删除id=1的记录
C:\Users\Administrator>db2 "select * from javan.tab2 where id=1"

ID          NAME
----------- --------------------
          1 1.25125888zjadolf

1 条记录已选择。

C:\Users\Administrator>db2 +c "delete from javan.tab2 where id=1"
DB20000I  SQL 命令成功完成。

C:\Users\Administrator>
C:\Users\Administrator>db2pd -db testdb -locks

Database Partition 0 -- Database TESTDB -- Active -- Up 0 days 00:01:56

Locks:
Address    TranHdl    Lockname                   Type       Mode Sts Owner
Dur HoldCount  Att        ReleaseFlg rrIID
0x7FB70980 2          41414141415A425A7F4760B841 Internal P ..S  G   2     
1   0          0x00000000 0x40000000 0
0x7FB72900 2          02000800040000000000000052 Row        ..X  G   2   ---一样的加了x row行级锁
1   0          0x00000020 0x40000000 0
0x7FB71E00 2          02000800000000000000000054 Table      .IX  G   2
1   0          0x00002000 0x40000000 0

---session 2 读取刚才删除id =2的记录
C:\Users\Administrator>db2 +c "select * from javan.tab2 where id=1"

ID          NAME
----------- --------------------
          1 1.25125888zjadolf

1 条记录已选择。

由于启用了未落实读 ,db2实现了类似oracle中undo 读的功能(虽然实现原理不一样)。
看一下ibm官方文档对 该新特性的描述:“当前已落实”(currently committed semantics,以后会简称 CC)新特性,
该新特性的显著特点是在游标稳定性(Cursor stability,以后会简称 CS)隔离级别时可以明显减少锁等待的出现,以及死锁的出现频率。

数据库配置参数 cur_commit

该数据库配置参数主要是用来控制游标稳定性扫描的行为,默认值为 ON,可选值为:

(1)ON :打开;

对于新创建的数据库,默认值是 ON,在此情况下,当你试图读取一个正在被其他应用程序修改的行时,将直接返回该行的当前已落实版本数据(也就是首次更改之前的值)。

(2)AVAILABLE:可用;

此值表示你的应用需要显式地请求“当前已落实行为”才能得到“当前已落实”结果。

(3)DISABLED:禁用;

如果数据库是从之前的版本升级而来,这个参数将被设置成 DISABLED,这是为了和以前版本的行为保持一致。如果你希望使用当前已落实来控制游标稳定性扫描的行为,需要将这个参数更改成 ON 。

需要注意的是,注册表变量 DB2_EVALUNCOMMITTED、DB2_SKIPDELETED 和 DB2_SKIPINSERTED 在启用 cur_commit 参数后会受到影响。在绑定(BIND)或预编译(PRECOMPILE)时对 CONCURRENTACCESSRESOLUTION 选项指定 USE CURRENTLY COMMITTED 或 WAIT FOR OUTCOME,那么注册表变量 DB2_EVALUNCOMMITTED、DB2_SKIPDELETED 和 DB2_SKIPINSERTED 将被忽略。

--附录
ORACLE Snapshot 隔离级别情况下的的堵塞情况
先出现的工作负载 \ 后出现的工作负载 读工作负载 写工作负载
读工作负载                          否(不堵塞) 否(不堵塞)
写工作负载                          否(不堵塞) 是(堵塞)

DB2 V9.7 之前的版本中使用 CS 隔离级别情况下的堵塞情况
先出现的工作负载 \ 后出现的工作负载 读工作负载 写工作负载
读工作负载                          否(不堵塞) 可能
写工作负载                          是(堵塞) 是(堵塞)

DB2 V9.7 中启用“当前已落实”的 CS 隔离级别情况下的堵塞情况
先出现的工作负载 \ 后出现的工作负载 读工作负载 写工作负载
读工作负载                        否(不堵塞) 否(不堵塞)
写工作负载                        否(不堵塞) 是(堵塞)

db2 v9.7 新特性cur_commit 能够实现未提交读新特性cur_commit 能够实现未提交读的更多相关文章

  1. [置顶] 老孟 DB2 V9.7 ESE(一)产品部署 基于centOS 6.4

    本文安装系统CENTOS 6.4 DB2位数64 安装中涉及目录位置各位可自行定义 生产系统为安全和性能考虑,一般将DB2实例目录.日志目录.归档日志目录.表空间目录区分开,可建立/db2home / ...

  2. atitit.Servlet2.5 Servlet 3.0 新特性 jsp2.0 jsp2.1 jsp2.2新特性

    atitit.Servlet2.5 Servlet 3.0 新特性 jsp2.0 jsp2.1 jsp2.2新特性   1.1. Servlet和JSP规范版本对应关系:1 1.2. Servlet2 ...

  3. [Android 新特性] 改进明显 Android 4.4系统新特性解析

    Android 4.3发布半年之后,Android 4.4随着新一代Nexus5一起出现在了用户的面前,命名为从之前的Jelly Bean(果冻豆)换成了KitKat(奇巧).这个新系统究竟都有怎样的 ...

  4. 3.0.0 alpha 重磅发布!九大新功能、全新 UI 解锁调度系统新能力

    2022 年 4 月 22 日,Apache DolphinScheduler 正式宣布 3.0.0 alpha 版本发布!此次版本升级迎来了自发版以来的最大变化,众多全新功能和特性为用户带来新的体验 ...

  5. 如何向Openstack社区提交一个新项目

    前几天有个朋友问我:自己有一个idea不错的项目,也把基本的框架写好了,想贡献到Openstack社区,却不知道应该怎么做.正好之前我有过类似的经历,那么来分享一下我是如何向Openstack社区提交 ...

  6. “新浪UC”的后江湖时代------易名新浪SHOW重出江湖

        说到新浪UC,相信很多老网民应该并不陌生,当年QQ放号收费让新浪UC火爆了好一阵子,而随着QQ的崛起,UC也就渐渐退出了即时通信市场,不过,这并不意味着新浪UC退出了历史舞台,因为目前炙手可热 ...

  7. Rendertron:谷歌 Chrome 新的 headless 模式又贡献了一个新的技巧

    摘自:https://zhuanlan.zhihu.com/p/31670033 Rendertron:JavaScript Web 富应用的一个老问题是如何使这些页面的动态渲染部分可供搜索引擎检索. ...

  8. Git库搭建好之后,当要提交一个新的文件,需要做的是3个步骤

    Git库搭建好之后,当要提交一个新的文件,需要做的是3个步骤 1.git add new.txt 2.git commit -m "add a new file" 3.git pu ...

  9. 人社部新职业,Panda Global发现区块链新职业榜上有名!

    近日,为了助力新冠肺炎疫情的防控,扎实做好"六稳"工作,全面落实"六保"任务,促就业拓岗位,人力资源社会保障部联合市场监管总局.国家统计局近日正式向社会发布一批 ...

随机推荐

  1. 微软BI 之SSRS 系列 - 如何让报表在一页显示,两种常用的技巧

    通常情况下,SSRS 报表在页面内容过多的时候会自动分页.但有的时候当页面内容不是很多,大概最多2页的情况下,或者客户要求所有内容必须在一页显示时,应该如何设置. 实际上,要考虑两种情况:第一种情况是 ...

  2. httpclient检查某个链接是否可用

    private boolean checkUrlIsValid(String url) { CloseableHttpClient httpClient = HttpClients.createDef ...

  3. 训练集测试集划分 train_test_split(X, y, stratify=y)

    from sklearn.model_selecting import train_test_spilt() 参数stratify: 依据标签y,按原数据y中各类比例,分配给train和test,使得 ...

  4. IT? 挨踢

    中国的IT,是最憋屈的IT. 他们掌握着正常人看不懂的英文+字母+标点符号组成的各类代码语言 他们像作者一样从无到有,从空白的白纸上敲出上千上万条华丽的计算机语言 但是他们承受着正常人的鄙视: 我的需 ...

  5. .Net可扩展的单据编号生成器-SNF.CodeRule--SNF快速开发平台3.2

    1.背景 在企业应用中单据编号的自定义是一个很常见的需求,如工号.业务单据编码等,能不能抽象一个通用的框架呢? 2.思路 这里的难点在于实现"解释器",比如将"前缀&qu ...

  6. struts2:struts.properties配置文件介绍及常量加载顺序

    1. 背景 struts2框架中有两个核心配置文件,其中struts.xml文件主要负责管理应用中的action映射,以及该action包含的result定义等.除此之外,struts2框架还包括一个 ...

  7. eoe移动开发者大会—移动开发者的极客盛宴 2013年9月14日期待您的加入!!

    2013 eoe移动开发者大会北京站即将盛大开启!      大会介绍 由国内最大的移动开发者社区eoe主办,在行业盟友的倾力支持下,集合了来自微软.Google.亚马逊.ARM等跨国公司业务负责人的 ...

  8. git 创建标签

    在Git中打标签非常简单,首先,切换到需要打标签的分支上: $ git branch * dev master $ git checkout master Switched to branch 'ma ...

  9. 【XMPP】XMPP协议之原理篇

    XMPP协议简介 XMPP协议(Extensible Messaging and Presence Protocol,可扩展消息处理现场协议)是一种基于XML的协议. 目的是为了解决及时通信标准而提出 ...

  10. win7(64bit)+python3.5+pyinstaller3.2安装和测试

    最近因为做项目需要,需要在win7中安装pyinstaller用于将.py文件生成脱离python平台的可执行程序*.exe文件. 安装步骤 第一步:安装python3.5 [下载python3.5的 ...