概述
Oracle提供了一个SQL调优健康检查脚本(SQLHC),用于检查需要优化的SQL的运行环境,生成报告以便帮助DBA找到SQL性能不佳的原因。SQLHC是SQLT的一个子集(我后续的文章会介绍SQLT),但SQLHC与SQLT不同,SQLHC不需要在数据库中安装任何代码即可完成收集信息的工作。
这个脚本执行下面几个方面的健康检查:
- 与SQL语句相关的对象的统计信息
- CBO参数
- CBO系统统计信息
- CBO数据字典统计信息
- CBO动态性能视图统计信息
安装过程
从MOS(My Oracle Support )的Doc ID 11366133.1中下载“sqlhc.zip”文件到数据库服务器,然后将内容解压缩到适当的目录中:
$ unzip sqlhc.zip
Archive: sqlhc.zipcreating: sqlhc/inflating: sqlhc/sqldx.sqlinflating: sqlhc/sqlhc.sqlinflating: sqlhc/sqlhc_pxhcdr.sqlinflating: sqlhc/sqlhc_pxhcdr_null.sqlinflating: sqlhc/sqlhc_sta.sqlinflating: sqlhc/sqlhc_tcb.sqlinflating: sqlhc/util_planx.sqlcreating: sqlhc/utl/inflating: sqlhc/utl/bde_chk_cbo.sqlinflating: sqlhc/utl/coe_gen_sql_patch.sqlinflating: sqlhc/utl/coe_gen_sql_profile.sqlinflating: sqlhc/utl/coe_load_sql_baseline.sqlinflating: sqlhc/utl/coe_load_sql_profile.sqlinflating: sqlhc/utl/coe_xfr_sql_profile.sqlinflating: sqlhc/utl/coe_xfr_sql_profile_remote.sqlinflating: sqlhc/utl/flush_cursor.sqlcreating: sqlhc/utl/mon/inflating: sqlhc/utl/mon/0_mon_readme.txtinflating: sqlhc/utl/mon/1_mon_repository.sqlinflating: sqlhc/utl/mon/2_mon_capture.sqlinflating: sqlhc/utl/mon/3_mon_reports.sqlinflating: sqlhc/utl/mvhcdr.sqlinflating: sqlhc/utl/planx.sqlinflating: sqlhc/utl/profiler.sqlinflating: sqlhc/utl/pxhcdr.sqlinflating: sqlhc/utl/readme.txtcreating: sqlhc/utl/spm/inflating: sqlhc/utl/spm/alter_spb.sqlinflating: sqlhc/utl/spm/coe_load_sql_baseline.sqlinflating: sqlhc/utl/spm/create_spb_from_awr.sqlinflating: sqlhc/utl/spm/create_spb_from_cur.sqlinflating: sqlhc/utl/spm/create_spb_from_sts.sqlinflating: sqlhc/utl/spm/create_sts_from_awr.sqlinflating: sqlhc/utl/spm/create_sts_from_cur.sqlinflating: sqlhc/utl/spm/display_awr.sqlinflating: sqlhc/utl/spm/display_cur.sqlinflating: sqlhc/utl/spm/display_spb.sqlinflating: sqlhc/utl/spm/display_sts.sqlinflating: sqlhc/utl/spm/drop_cur.sqlinflating: sqlhc/utl/spm/drop_spb.sqlinflating: sqlhc/utl/spm/drop_sts.sqlinflating: sqlhc/utl/spm/evolve_spb.sqlinflating: sqlhc/utl/spm/imp_and_unpack_spb.sqlinflating: sqlhc/utl/spm/imp_and_unpack_sts.sqlinflating: sqlhc/utl/spm/pack_and_exp_spb.sqlinflating: sqlhc/utl/spm/pack_and_exp_sts.sqlinflating: sqlhc/utl/spm/readme.txt
运行SQLHC脚本
要运行该脚本,请执行以下步骤:
- 使用SYS账户或具有访问数据字典视图权限的用户连接到SQL*Plus。
- 登录到相应的容器,否则您将无法访问对象。
- 运行“sqlhc.sql”脚本。
这里输入两个必需的参数: - Oracle Pack许可证(调优、诊断或无)[T|D|N]。SQLHC不需要许可证并且是免费的,但是如果安装了诊断包或调优包,SQLHC可以使用AWR报告中的信息,因此它会询问您的服务器是否已经被授权了诊断包或调优包。如果有,则输入“T”。
- 要分析的SQL的有效SQL_ID。请不要输入PL/SQL包的SQL_ID,因为这样虽然不会引发错误,也不会产生有用的结果。
例如:
SQL>@sqlhc/sqlhc.sql T 5mz8u3b34u9gw
这个脚本运行后,将在执行的同一目录中生成一个ZIP文件。
$ ll
total 208
-rw-r--r--. 1 oracle oinstall 212247 Mar 12 17:52 sqlhc_20240312_1751_5mz8u3b34u9gw.zip
$ unzip sqlhc_20240312_1751_5mz8u3b34u9gw.zip
Archive: sqlhc_20240312_1751_5mz8u3b34u9gw.zipinflating: sqlhc_20240312_1751_5mz8u3b34u9gw_1_health_check.htmlinflating: sqlhc_20240312_1751_5mz8u3b34u9gw_2_diagnostics.htmlinflating: sqlhc_20240312_1751_5mz8u3b34u9gw_3_execution_plans.htmlinflating: sqlhc_20240312_1751_5mz8u3b34u9gw_4_sql_detail.htmlextracting: sqlhc_20240312_1751_5mz8u3b34u9gw_9_log.zipinflating: sqlhc_20240312_1751_5mz8u3b34u9gw_10_sql_tuning_advisor.outinflating: sqlhc_20240312_1751_5mz8u3b34u9gw_6_10053_trace_from_cursor.trcextracting: sqlhc_20240312_1751_5mz8u3b34u9gw_11_tcb.zipextracting: sqlhc_20240312_1751_5mz8u3b34u9gw_8_sqldx.zip
下面是生成的HTML文件的样本: