您的位置:首页 > 数据库

启用SQL*Plus的AutoTrace功能

2014-02-16 20:25 225 查看
AUTOTRACE是一项SQL*Plus功能,自动跟踪为SQL语句生成一个执行计划并且提供与该语句的处理有关的统计。
SQL*Plus AUTOTRACE可以用来替代SQL Trace使用,AUTOTRACE的好处是您不必设置跟踪文件的格式,并且它将自动为SQL语句显示执行计划。然而,AUTOTRACE分析和执行语句;而EXPLAIN PLAN仅分析语句。
使用AUTOTRACE不会产生跟踪文件。
 
一 setautotrace语法及选项的说明
(1)用法:SET AUTOTRACE {OFF | ON |TRACEONLY} [EXPLAIN] [STATISTICS]
OPTION说明
SET AUTOTRACE OFF
此为默认值,即关闭Autotrace
SET AUTOTRACE ON
同时输出执行结果以及统计信息和执行计划信息。
SET AUTOTRACE ON EXPLAIN
只打开执行计划报表,显示命令结果,不显示统计信息。
SET AUTOTRACE ON STATISTICS
只打开统计信息报表,显示命令结果,不显示执行计划。
SET AUTOTRACE TRACEONLY
不显示命令的执行结果,显示执行计划和统计信息,但在traceonly的后面仍然可以追加explain或者statistics,等同于set autotrace on [explain|statistics]但是不显示执行结果。
 
(2)Autotrace执行计划的各列的涵义
ID_PLUS_EXP
每一步骤的行号
PARENT_ID_PLUS_EXP
每一步的Parent的级别号
PLAN_PLUS_EXP
实际的每步
OBJECT_NODE_PLUS_EXP
Dblink或并行查询时才会用到
 
(3)AUTOTRACE Statistics常用列解释
db block gets
从buffer cache中读取的block的数量
consistent gets
从buffer cache中读取的undo数据的block的数量
physical reads
从磁盘读取的block的数量
redo sizeDML
生成的redo的大小
sorts (memory)
在内存执行的排序量
sorts (disk)
在磁盘上执行的排序量
 
二 使用前设置及Autotrace授权
(1)任何以SQL*PLUS连接的session都可以用Autotrace,不过还是要做一些设置的,否则可能报错。
报错示例:
SQL:> set autotrace on;
SP2-0613: Unable to verify PLAN_TABLE format or existence
SP2-0611: Error enabling EXPLAIN report
SP2-0618: Cannot find the Session Identifier. Check PLUSTRACE role is enabled
SP2-0611: Error enabling STATISTICS report
该错误的的主要原因是由于当前用户下没有PLAN_TABLE这张表及相应的PLUSTRACE角色权限。
(2)通过以下方法可以把Autotrace的权限授予Everyone,如果你需要限制Autotrace权限,可以把对public的授权改为对特定user的授权。
1 切换到目录<ORACLE_HOME>/rdbms/admin
2 以sysdba登录SQL*Plus
3 运行@utlxplan.sql
4 运行create public synonym plan_table for plan_table;
5 运行grant all on plan_tableto public;
6 切换到目录<ORACLE_HOME>/sqlplus/admin
7 以sysdba登录SQL*Plus
8 运行@plustrce.sql
9 运行grant plustrace topublic;
 
三 使用AutoTrace的功能
SQL> set autotrace on
SQL> set timing on
SQL> set autotrace traceonly

四 补充:
查询tab视图时报错:
ERROR:

ORA-01039: 视图基本对象的权限不足

SP2-0612: 生成 AUTOTRACE EXPLAIN 报告时出错
出现该错误的原因是用户对底层的数据字典没有访问权限,可通过以下语句解决:
grant select any dictionary to user_name;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  Oracle SQLPlus autotrace