DB2对sql语句的性能检测

因为工作中的需要,对一些sql语句引起死锁,要彻底地查一遍,即DB2对sql语句的性能检测, 不然老是down机;下面是操作步骤:

在DB2命令窗口DB2 CLP状态下:
1、启动db2数据管理器
D:\Program Files\IBM\SQLLIB\BIN>db2 db2start
DB20000I DB2START 命令成功完成。
2、链接数据库
D:\Program Files\IBM\SQLLIB\BIN>db2 connect to cndb

数据库连接信息

数据库服务器         = DB2/NT 8.1.0
SQL 授权标识        = DB2ADMIN
本地数据库别名       = CNDB

3、查看DB2监控器状态
db2 select evmonname, EVENT_MON_STATE(evmonname) as state from syscat.eventmonitors
/
举例输出为

EVMONNAME       STATE

——————————– ——–

DB2DETAILDEADLOCK      1
注:STATE=0 表明事件监视器的开关为“关闭”状态,连接数据库后,这样的事件监视器不会打开相应的数据库管理器监视器的开关;
STATE=1 表明开关为“打开”状态,连接数据库后,这样的事件监视器将打开相应的数据库管理器监视器的开关。
///
4:创建sql语句的监视器
D:\Program Files\IBM\SQLLIB\BIN>db2 create event monitor statmon for statements
write to file ‘f:\ibm\butone\statmon’
DB20000I SQL 命令成功完成。

使该会话一直处于打开状态,直到这些数据库活动完成。请确保f:\ibm\butone\statmon目录有足够大的空间来保存跟踪文件。
这里选择 f:\ibm\butone\statmon 目录是因为所有用户都可以访问该目录;但也可以选择使用其它目录(请确保对于该目录,DB2 有访问权限)。目录的大小取决于用户想要捕获的 SQL 语句的数目。一开始,最好设为500MB。

///

5:创建目录
D:\Program Files\IBM\SQLLIB\BIN>md f:\ibm\butone\statmon

6:启动监视器
D:\Program Files\IBM\SQLLIB\BIN>db2 set event monitor statmon state 1
DB20000I SQL 命令成功完成。
/
执行正常的数据库活动(即访问你的网站,点击任何用到数据库的页面),直到您想监控的时段结束。这一监控阶段可以是问题产生时期,也可以是通常的数据库活 动过程。在 f:\ibm\butone\statmon目录下,您应该可以看到一组扩展名为“ .evt ”的文件。这些文件就是您的事件监视器文件。

7:完成输出

D:\Program Files\IBM\SQLLIB\BIN>db2 flush event monitor statmon buffer
DB20000I SQL 命令成功完成。

8:关闭监视器
D:\Program Files\IBM\SQLLIB\BIN>db2 set event monitor statmon state=0
DB20000I SQL 命令成功完成。
D:\Program Files\IBM\SQLLIB\BIN>db2 terminate
DB20000I TERMINATE 命令成功完成。

9:格式化输出
D:\Program Files\IBM\SQLLIB\BIN>db2evmon -path f:\ibm\butone\statmon > f:\ibm\butone\sqltrce.txt

Reading f:\ibm\butone\statmon\00000000.EVT …

Reading f:\ibm\butone\statmon\00000001.EVT …


在单个文件 sqltrace.txt 中会有所有已捕获的 SQL 语句及其细节。
在sqltrce.txt里面就可以看到执行过的所有sql语句;注意查看sqltrce.txt中的sql语句的执行时间

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值