DB2数据库为单个会话锁定的实际操作技巧

数据库
以下的文章主要向大家讲述的是DB2数据库为单个会话锁定的实际操作技巧,以及对其在实际操作中要用到的实际操作语句的描述。

我们今天是要和大家一起讨论的是DB2数据库为单个会话锁定的实际操作技巧,DB2从版本8.2开始,客户可以对每一个DB2会话指定相关的锁定策略。在以前的版本中,只能通过配置DB2数据库配置参数LOCKTIMEOUT配置一个应用程序如果不能获得锁,等待多长时间将回滚该事务。

 

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

 

 

  1. connect to sample   
  2. select * from test 

 

 

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

 

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

 

  1. set current lock timeout not wait   
  2. select * from test 

 

 

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

 

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

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

 

  1. LOCKTIMEOUT = WAIT | NOT WAIT | WAIT seconds | seconds 

 

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

 

“SET CURRENT LOCK TIMEOUT”重置。

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

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

 

  1. connect to sample   
  2. select * from test 

 

 

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

 

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

 

  1. set current lock timeout not wait   
  2. select * from test 

 

 

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

 

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

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

 

  1. LOCKTIMEOUT = WAIT | NOT WAIT | WAIT seconds | seconds 

 

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

 

“SET CURRENT LOCK TIMEOUT”重置。

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

【编辑推荐】

  1. 让DB2数据库对所有内存进行使用
  2. DB2 聚集目标表的关键作用分析
  3. DB2数据库中聚集目标表的功能是什么?
  4. DB2 Resotre的使用技巧的描述
  5. DB2数据库如何正确取得当前时间
责任编辑:佚名 来源: 电子工业出版社
相关推荐

2011-05-13 10:32:54

DB2数据库

2009-06-04 17:53:24

DB2数据库单个会话锁定LOCKTIMEOUT

2010-08-02 14:50:41

DB2数据库

2010-09-07 10:36:56

DB2数据库

2010-08-04 16:52:23

2010-07-30 11:01:55

2010-08-02 09:10:45

JDBC连接DB2

2010-08-18 09:18:10

DB2求剩余数据库空间

2010-08-03 13:56:11

DB2表复制

2010-07-30 14:38:25

DB2数据库

2010-08-12 09:25:22

DB2数据库复原

2010-08-12 09:06:30

DB2数据库自动备份

2010-08-03 09:49:58

DB2恢复数据库

2010-08-17 13:25:39

DB2恢复删除表

2010-08-05 09:33:31

DB2数据库卸载

2010-09-07 13:04:20

DB2数据库

2010-08-05 13:10:11

DB2代码

2010-08-03 09:32:19

DB2在线备份

2010-07-30 14:21:10

DB2数据集

2010-08-10 16:41:42

DB2手工添加
点赞
收藏

51CTO技术栈公众号