【锁等待】如何快速获取所等待的sql
牛大叔的书里有个很实用的Sql:
select AGENT_ID ,substr(STMT_TEXT,1,100) as
statement,STMT_ELAPSED_TIME_MS from table
(SNAPSHOT_STATEMENT('sample',-1)) asBwhere AGENT_ID
in (select AGENT_ID_HOLDING_LK from table(SNAPSHOT_LOCKWAIT
('sample',-1)) as A order by LOCK_WAIT_START_TIME
ASC FETCH FIRST 20 ROWS ONLY ) order by STMT_ELAPSED_TIME_MS DESC
可是,在我的性能测试环境中(V9.5)总是返回 0 records,即使,我的数据库有许多锁等待
问题1:如何通过表函数获取锁等待的sql?
问题2:我一般用db2pd来抓取所等待sql,但是却有不知道该sql等待时间,很难判定该sql是否有问题,有什么其他办法可以去获得么?
请教专家。
select AGENT_ID ,substr(STMT_TEXT,1,100) as
statement,STMT_ELAPSED_TIME_MS from table
(SNAPSHOT_STATEMENT('sample',-1)) asBwhere AGENT_ID
in (select AGENT_ID_HOLDING_LK from table(SNAPSHOT_LOCKWAIT
('sample',-1)) as A order by LOCK_WAIT_START_TIME
ASC FETCH FIRST 20 ROWS ONLY ) order by STMT_ELAPSED_TIME_MS DESC
可是,在我的性能测试环境中(V9.5)总是返回 0 records,即使,我的数据库有许多锁等待
问题1:如何通过表函数获取锁等待的sql?
问题2:我一般用db2pd来抓取所等待sql,但是却有不知道该sql等待时间,很难判定该sql是否有问题,有什么其他办法可以去获得么?
请教专家。
作者: xxzmxx 发布时间: 2011-08-17
板凳先坐了,哈哈
作者: xxzmxx 发布时间: 2011-08-17