设为首页 收藏本站
查看: 959|回复: 0

[经验分享] db2 sql调优

[复制链接]

尚未签到

发表于 2016-11-17 10:02:14 | 显示全部楼层 |阅读模式
  当我们发现某个SQL语句执行很慢时,可以通过查看它的访问计划来定位原因,如是否执行了合适的索引、是否采用了正确的连接方法等。
但是我们发现很多用户对访问计划的生成和解释工具的使用存在很多疑惑,本文通过一些实例来解释具体的用法,希望对大家有所帮助。
  步骤1. 创建explain表
    访问计划的采集和评估是通过一些explain命令和工具实现的,在采集和评估之前需要先创建一些数据表来存放解释数据。
在<db2_inst>/sqllib/misc下有个文件叫EXPLAIN.DDL
db2 connect to <db>
db2 -tvf <db2_inst>/sqllib/misc/EXPLAIN.DDL (unix和linux下注意大小写)
在当前数据库中会生成9张解释表,第2步采集的解释数据会存放到这些表中。
  步骤2. 采集explain数据和explain snapshot数据
explain数据包含关于一条 SQL 语句的访问计划的详细信息。此信息跨多个不同的解释表存储。
explain shapshot数据包含一条 SQL 语句的当前内部表示以及所有相关信息。此信息存储在 EXPLAIN_STATEMENT 解释表的 SNAPSHOT 列中。
explain和explain snapshot的解释数据采集有如下几种方法:
执行 EXPLAIN SQL 语句 设置 CURRENT EXPLAIN MODE 特殊寄存器/CURRENT EXPLAIN SNAPSHOT 特殊寄存器   
在 PRECOMPILE 或 BIND 命令中使用 EXPLAIN 或 EXPLSNAP 绑定选项 Explain SQL:
explain语句为单条动态SQL语句收集解释数据,如
explain plan for "select * from employee"
Current explain mode为多条动态SQL语句收集解释数据:
db2 set current explain mode explain (打开注册变量为explain模式)
db2 "select * from employee"
db2 "select * from department"
...
db2 set current explain mode no (关闭解释模式)
Prep(或延迟bind) ...explain为嵌入式(如SQLC等)SQL语句收集解释数据:
db2 prep myapp.sqc explain yes explsnap yes
  步骤3. 查看和评估解释数据
DB2提供了如下几个查看工具,其中db2exfmt最为强大,其余两个可辅助。
 db2expln  db2exfmt  Visual Explain
db2exfmt -d <db> -g tic -s % -n % -# 0 -w -1 -o explain1.txt
具体命令的使用请参看DB2 command reference或信息中心
  
DB2 db2top性能监控命令用法-找出最频繁、最耗时的SQL

db2top -d 数据库 -u 用户名 -p 密码
按D,进入动态sql监控  www.iyunv.com  
按z,倒序排序
输入列的数据,序号是从0开始
按L,输入sql的序列号,查看sql明细
  
db2中查找top sql
$ db2 get snapshot for dynamic sql on testdb
  Dynamic SQL Snapshot Result
  Database name = testdb
  Database path = /home/db2inst1/db2inst1/NODE0000/SQL00001/
  Number of executions = 0
Number of compilations = 0
Worst preparation time (ms) = 1
Best preparation time (ms) = 1
Internal rows deleted = Not Collected
Internal rows inserted = Not Collected
Rows read = Not Collected
Internal rows updated = Not Collected
Rows written = Not Collected
Statement sorts = Not Collected
Statement sort overflows = Not Collected
Total sort time = Not Collected
Buffer pool data logical reads = Not Collected
Buffer pool data physical reads = Not Collected
Buffer pool temporary data logical reads = Not Collected
Buffer pool temporary data physical reads = Not Collected
Buffer pool index logical reads = Not Collected
Buffer pool index physical reads = Not Collected
Buffer pool temporary index logical reads = Not Collected
Buffer pool temporary index physical reads = Not Collected
Total execution time (sec.ms) = Not Collected
Total user cpu time (sec.ms) = Not Collected
Total system cpu time (sec.ms) = Not Collected
Statement text = select * from tb1
  执行时间: Total execution time (sec.ms)/Number of executions
  查找执行时间非常长的sql文。
  db2找出执行时间最长的dynamic sql 2010-08-31 13:53:35
分类:
  db2 get monitor switches
查看snapshot的各个开关,将这些开关都打开,
  db2 update monitor switches using BUFFERPOOL ON
db2 update monitor switches using LOCK ON
db2 update monitor switches using SORT ON
db2 update monitor switches using STATEMENT ON
db2 update monitor switches using TABLE ON
db2 update monitor switches using TIMESTAMP ON
db2 update monitor switches using UOW ON
  执行下面的命令抓取dynamic sql的信息
db2 get snapshot for dynamic sql on orsdb > dynamic.out
  cat dynamic.out|grep 'Total execution time' > time.out
  cat time.out|sort -n +5
最下面的即为消耗时间最多的dynamic sql, 但是还需要看该sql的执行次数,这样可以计算出执行一次这样的sql语句需要
多长时间,找到消耗时间最多的sql语句,看能否做一些优化及调整,
  用此方法同时能够得到cost最大的语句
db2 get snapshot for all on sample > snap.out  
  attach命令: 用于解决sql1428N错误
1.本地数据库
db2 attach to <node name>
2.远端数据库
db2 attach to <node name> user <username> using <password>
  
terminate命令:
db2 drop database dbname
在完成这一过程之前要确保所有用户已经断开连接,包括你自己。
db2 terminate
db2 force applications all
通过下面的命令可以看看是不是都清除了连接。
db2 list applications

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-301570-1-1.html 上篇帖子: DB2常用命令 下篇帖子: db2 创建数据库及表空间语句
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表