iojsioi 发表于 2016-11-14 10:08:23

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语句的执行时间
////////////////////////////////////////////////////////////////////////////////////////////////////
页: [1]
查看完整版本: DB2对sql语句的性能检测