oracle中关于autotrace工具的使用(有示例)
上一篇 / 下一篇 2010-12-10 10:59:06 / 个人分类:ORACLE
SQLPLUS的AutoTrace是分析SQL的执行计划,执行效率的一个非常简单方便的工具,在绝大多数情况下,也是非常有用的工具。利用AutoTrace工具提供的SQL执行计划和执行状态可以为我们优化SQL的时候提供优化的依据,以及优化效果的明显的对比效果。 AutoTrace只能在只有oracle的工具才有,比如sql developer和sql plus,PL/SQL的执行计划不准确。
AutoTrace与其他小工具的区别:
SQL*Plus AUTOTRACE 可以用来替代 SQL Trace 使用,AUTOTRACE的好处是您不必设置跟踪文件的格式,并且它将自动为 SQL 语句显示执行计划。然而,AUTOTRACE 分析和执行语句,而EXPLAIN PLAN仅分析语句。 使用AUTOTRACE不会产生跟踪文件。sql trace会在后台udump目录中残生一个trc文件,并且是二进制的,还得使用tkprof进行编译才能看到统计。
用法:
SET AUTOT[RACE] {OFF | ON | TRACE[ONLY]} [EXP[LAIN]] [STAT[ISTICS]]
举例:
SET AUTOT[RACE] OFF 停止AutoTrace
SET AUTOT[RACE] ON 开启AutoTrace,显示AUTOTRACE信息和SQL执行结果
SET AUTOT[RACE] TRACEONLY 开启AutoTrace,仅显示AUTOTRACE信息
SET AUTOT[RACE] ON EXPLAIN 开启AutoTrace,仅显示AUTOTRACE的EXPLAIN信息
SET AUTOT[RACE] ON STATISTICS开启AutoTrace,仅显示AUTOTRACE的STATISTICS信息
结果解释
physical reads 物理读——执行SQL的过程中,从硬盘上读取的数据块个数
redo size 重做数——执行SQL的过程中,产生的重做日志的大小
bytes set via sql*net to client 通过sql*net发送给客户端的字节数
bytes received via sql*net from client 通过sql*net接受客户端的字节数
sorts(memory) 在内存中发生的排序
sorts(disk) 不能在内存中发生的排序,需要硬盘来协助
rows processed 结果的记录数
总结:
AutoTrace是ORACLE中优化工具中最基本的工具,虽然功能比较有限,但足以满足我们日常工作的需要。
在Oracle9i中需要运行$ORACLE_HOME\RDBMS\ADMIN\utlxplan.sql脚本生成plan_table表;
在Oracle10g中PLAN_TABLE不再需要创建,Oracle缺省增加了一个字典表PLAN_TABLE$,然后基于PLAN_TABLE$创建公用同义词供用户使用
关于Autotrace几个常用选项的说明:
SET AUTOTRACE OFF ---------------- 不生成AUTOTRACE 报告,这是缺省模式
SET AUTOTRACE ON EXPLAIN ------ AUTOTRACE只显示优化器执行路径报告
SET AUTOTRACE ON STATISTICS -- 只显示执行统计信息
SET AUTOTRACE ON ----------------- 包含执行计划和统计信息
SET AUTOTRACE TRACEONLY ------ 同set autotrace on,但是不显示查询输出
SQL>set autotrace on; //查看sql执行计划 USERNAME USER_ID
-------------------------------------------------------------------------- Predicate Information (identified by operation id): 1 - filter("USERNAME"='ORACLE')
SQL> select username,user_id from test where rownum<5; USERNAME USER_ID
--------------------------------------------------------------------------- Predicate Information (identified by operation id): 1 - filter(ROWNUM<5)
SQL> set timeing on USERNAME USERNAME 22 rows selected. Elapsed: 00:00:00.08 Execution Plan --------------------------------------------------------------------------
SQL> select count(*) from test; COUNT(*) Elapsed: 00:00:00.01 Execution Plan -------------------------------------------------------------------
SQL> |
TAG:
标题搜索
日历
|
|||||||||
日 | 一 | 二 | 三 | 四 | 五 | 六 | |||
1 | 2 | 3 | 4 | 5 | 6 | ||||
7 | 8 | 9 | 10 | 11 | 12 | 13 | |||
14 | 15 | 16 | 17 | 18 | 19 | 20 | |||
21 | 22 | 23 | 24 | 25 | 26 | 27 | |||
28 | 29 | 30 |
我的存档
数据统计
- 访问量: 330870
- 日志数: 218
- 图片数: 5
- 文件数: 7
- 建立时间: 2007-01-08
- 更新时间: 2012-11-03