重庆思庄Oracle、Redhat认证学习论坛
标题:
SQL性能分析工具sqlhc简单介绍
[打印本页]
作者:
mahan
时间:
2023-9-10 13:11
标题:
SQL性能分析工具sqlhc简单介绍
执行方法:
使用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
第一个参数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是通常存在的
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
欢迎光临 重庆思庄Oracle、Redhat认证学习论坛 (http://bbs.cqsztech.com/)
Powered by Discuz! X3.2