SQL性能分析工具sqlhc简单介绍

149 篇文章 21 订阅

sqlhc是老虎刘最常用的SQL优化工具,没有之一。这个工具在oracle 的 MOS网站可以下载,原压缩包里面有3个文件,老虎刘一般只用sqlhc.sql一个文件。

sqlhc是SQL health check的简称,能够收集sql相关的表、索引、统计信息、优化器参数、SQL执行情况、等待事件等信息,可以帮你检查SQL存在的问题并优化SQL。使用sqlhc之前,首先要提供要检查或优化的SQL的sql_id,一般DBA都知道sql_id,遗憾的是有些初级研发人员却不知道sql_id为何物,自己百度一下,非常简单。

通常情况下,我们会取AWR报告的TOP SQL进行性能分析。

 

执行方法:

使用sqlplus 连到数据库(建议用DBA用户,因为要访问一些性能视图),两种执行方法(注意:10g版本执行过程还需要输入一个参数,直接回车即可):

1、一次输入两个参数:

SQL>@sqlhc T sql_id

2、根据提示依次输入参数:

SQL> @sqlhc 

Parameter 1:

Oracle Pack License (Tuning, Diagnostics or None) [T|D|N] (required)

Enter value for 1: T

第一个参数,根据购买License情况选择T、D或N(大多数人会选择T)

PL/SQL procedure successfully completed.

Parameter 2:

SQL_ID of the SQL to be analyzed (required)

Enter value for 2: 9kpzwpgf7gdz2  

第二个参数:你要检查优化的SQL的sql_id

......具体执行过程较长,省略

执行过程大概几分钟到半小时不等(根据AWR保存周期、字典表大小不同相差较大,一般系统应该在5分钟以内能够完成),在生产系统上执行不要紧张,对系统基本无影响!

执行过程有log,也有屏显。执行过程会insert 数据到plan_table表,执行结束会rollback。

 

执行完成后会在当前目录下生成一个类似下面形式的一个zip文件:sqlhc_20160722_170249_1g33tgkybp2sv.zip 文件名以sqlhc开头,依次是日期、时间、sql_id。

压缩包内的文件一般如下图所示,其中4个html文件和log.zip是通常存在的。

10053 trace文件的生成需要11.2版本以上,sql_id仍在library cache内的情况下。

如果*sql_monitor.zip 也包含在sqlhc压缩包内,说明你的SQL执行时间超过了5s,或者是并行的SQL,而且收集sqlhc时仍保留在sql monitor的内存。sql monitor对分析sql执行计划有很大帮助,这个工具也可以作为一个专门的主题。如果遇到问题收集sqlhc信息及时,就非常有可能收集到sql monitor文件。如果一个sql执行完后超过半小时没有收集sqlhc,sql monitor信息就就非常有可能被刷出内存。

 

主要分析的的3个html文件是:

  • *_health_check.html
  • *_diagnostics.html
  • *_execution_plan.html

具体内容非常丰富,自己动手看看吧,看多了你就成“老中医”了!找人帮忙时直接把zip文件发给对方,需要的信息基本上能够诊断分析和优化了。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值