新客网
首页 | 新闻 | 系统·网络·服务器·安全 | 工具·办公 | 编程·数据库 | 图象·网页·运营 | 硬件·存储 | 专题教程 | 旧版
 → 当前位置:首页 > 教程 > 数据库 > DB2教程 > 正文

DB2数据库为单个会话锁定技巧

XKER.COM   2006-8-28 11:10:10  来源:Developerworks中国  点击:

DB2从版本8.2开始,客户可以为每一个DB2会话指定锁定策略。在以前的版本中,只能通过配置数据库配置参数LOCKTIMEOUT配置一个应用程序如果不能获得锁,等待多长时间将回滚该事务。

单个会话现在可以指定锁定等待方式策略,该策略在会话需要的锁定不能立即获取时使用。该策略指示会话是否将采取如下措施:在不能获取锁定时返回 SQLCODE 和 SQLSTATE

无限等待锁定

等待为锁定指定的时间

等待锁定时使用 locktimeout 数据库配置参数的值

锁定等待方式策略通过新的 SET CURRENT LOCK TIMEOUT 语句指定,此语句更改 CURRENT LOCK TIMEOUT 专用寄存器的值。CURRENT LOCK TIMEOUT 专用寄存器指定在返回指示不能获取锁定的错误之前等待锁定的秒数。

虽然 locktimeout 参数的值适用于所有锁定,但是此新功能只影响以下锁定类型:行、表、索引键和多维群集(MDC)块锁定。

该语句的语法如下:

.-CURRENT-. .-=-.

>>-SET--+---------+--LOCK TIMEOUT--+---+------------>

>--+-WAIT-----------------------+------------><

+-NOT WAIT-------------------+

+-NULL-----------------------+

| .-WAIT-. |

+-+------+-- integer-constant -+

'- host-variable --------------'

关于该命令的详细说明,请参见:http://publib.boulder.ibm.com/infocenter/db2help/topic

/com.ibm.db2.udb.doc/admin/r0011874.htm?resultof=

%22%73%65%74%22%20%22%63%75%72%72%65%6e%74%22%2

0%22%6c%6f%63%6b%22%20%22%74%69%6d%65%6f%75%74%22%20

下面通过一个例子来讲解如何使用这个功能(我们使用SAMPLE数据库):

1、使用"db2 +c"打开两个DB2会话。(+c 参数关闭AUTOCOMMIT)

2、在一个会话中执行下面的语句:

connect to sample

create table test(id int,name char(10))

commit

insert into test values(1,'test')

3、在另一个会话中执行下面的语句:

connect to sample

select * from test

由于默认LOCKTIMEOUT参数设置为-1,所以这个会话会一直等着,没有结果返回。如下图所示:

4、下面我们在第一歌窗口中重复一样的操作,只是在第二个窗口中使用如下语句

set current lock timeout not wait

select * from test

我们看到select语句不会等待,而是直接返回错误。参见下图:

您可以自己采取上面的方法测试一下其他的参数设置。

该语句可以在程序中和存储过程中使用。另外这个功能对于CLI程序来讲,还可以方便地通过设置db2cli.ini文件配置关键字使用,关键字为:

LOCKTIMEOUT = WAIT | NOT WAIT | WAIT seconds | seconds

通过设置这个参数,DB2 CLI会自动根据设置值发送一条“SET CURRENT LOCK TIMEOUT”语句到DB2服务器,该参数值也可以通过在程序中显示使用

“SET CURRENT LOCK TIMEOUT”重置。本篇文章发表于www.xker.com(小新)

您可以根据您应用程序的需求,灵活运用这条语句设计合适的DB2会话锁定策略。

上一篇教程:使用XQuery查询DB2 XML数据
下一篇教程:DB2上机操作指令指南
收藏本文】 【我要投稿】 【打印本文】 【论坛讨论】 【关闭窗口

相关文章
·DB2 9数据库专题·DB2 9安装方法简介
·海关数据库专家王翔看好DB2 9的数据压缩性能·段云峰:DB2 9对企业有3点帮助
·银行数据库专家王明胜谈DB2 9·DB2专家王云谈商业智能BI
·DB2 9是信息数据管理的基石·DB2 9数据服务器发展3部曲
·DB2 9颠覆关系型数据库?·对比DB2 9和DB2 V8.x中的XML功能
·DB2 中的数据类型·DB2中的数据移动详解
·用shell抽取,更新db2的数据·IBM DB2 Connect简介
·DB2数据库设计和最高性能原则·DB2 如何提高IMPORT命令性能

学院文章搜索
  
推荐文章
·编程过把瘾:自己动手写操
·数据恢复指南 专题
·硬盘“逻辑锁”解决办法
·DOS使用中的常见问题解答
·DOS下常用的相关网络命令
·Win2000优化技巧篇之:硬件
·惊心8小时:破译Windows运行
·菜鸟必备:超实用低级格式
·硬件有价数据无价 硬盘开盘
·国内数据恢复市场内幕揭秘
阅读排行
·免费代理IP(每日更新)
·DB2 9数据库专题
·关于 Apache 的几种常见应
·QQ千人好友浮出水面 会员抢
·站长手册:WIN2003下Web服
·网站投资你和我的20个自身
·140天,从做站起步到日赚1
·Fdisk分区详解
·佳能活动 免费得QQ秀
·DOS下对系统重新进行分区
专题教程
·数据恢复指南 专题
·Web服务器专题
·DB2 9数据库专题
·ghost教程 专题
·局域网技术专题
·虚拟机专题
·CDN加速技术专题
·注册表教程专题
·电脑技巧 专题
·Linux与虚拟化技术
最新文章
·Firefox出现新高危0Day漏洞
·QQ千人好友浮出水面 会员抢
·DOS下对系统重新进行分区
·Fdisk分区详解
·DOS常用命令
·dos如何进行系统配置
·dos慎用命令
·Ver、Vol、Ctty命令使用说
·Tree、Unformat、Vsafe命令
·Setver、Share、Subst命令
设为首页 - 加入收藏 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
Copyright © 2003 - 2006 XKER Inc. All Rights Reserved
新客网 版权所有