启用SQL*Plus的AutoTrace功能

本文详细介绍了Oracle SQL*Plus中的AUTOTRACE功能,包括其语法、选项、执行计划及统计信息的含义,并提供了启用AUTOTRACE的步骤及常见错误解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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;




``` REM 生成临时 SQL 脚本 echo [%date% %time%] [DEBUG] 准备生成临时 SQL 脚本 >> "%LOG_FILE%" ( echo SET ECHO ON echo SET PAGESIZE 0 echo SET FEEDBACK OFF echo SET HEADING ON echo SPOOL "%OUTPUT_DIR%\%SAFE_CARD%.csv" echo SELECT t.card_sn AS 卡号^ , s.station_cn_name AS 车站^ , t.tran_date AS 日期^ , t.tran_time AS 时间^ FROM data_ykt_tran t^ , basi_station_info s^ WHERE t.card_sn='%%MY_CARD%%'^ AND t.tran_date BETWEEN '%%DATE_RANGE_START%%' AND '%%DATE_RANGE_END%%'^ AND t.station_id = s.station_id^ ORDER BY t.tran_date echo SPOOL off echo quit )> tmp_query.sql echo [%date% %time%] [DEBUG] 临时SQL脚本已生成 >> "%LOG_FILE%" REM 检查临时脚本是否生成 if not exist "D:\Akaoqin\tmp_query.sql" ( echo [%date% %time%] [ERROR] 无法生成 tmp_query.sql >> "%LOG_FILE%" goto :NEXT_CARD ) echo [%date% %time%] [DEBUG] 临时SQL脚本存在 >> "%LOG_FILE%" REM 执行 SQL*Plus echo [%date% %time%] [INFO] 正在执行 SQL*Plus 查询... >> "%LOG_FILE%" sqlplus -L %ORACLE_USER%/%ORACLE_PASSWORD%@//%ORACLE_DB% @D:\Akaoqin\tmp_query.sql >> "%LOG_FILE%" 2>&1 set "SQLPLUS_ERRORLEVEL=%ERRORLEVEL%" if not %SQLPLUS_ERRORLEVEL% equ 0 ( echo [%date% %time%] [ERROR] SQL*Plus 执行失败,错误代码: %SQLPLUS_ERRORLEVEL% >> "%LOG_FILE%" )```SET ECHO ON SET PAGESIZE 0 SET FEEDBACK OFF SET HEADING ON SPOOL "D:\Akaoqin\output_csv\0250001294.csv" SELECT t.card_sn AS 卡号 , s.station_cn_name AS 车站 , t.tran_date AS 日期 , t.tran_time AS 时间 FROM data_ykt_tran t , basi_station_info s WHERE t.card_sn='%MY_CARD%' AND t.tran_date BETWEEN '%DATE_RANGE_START%' AND '%DATE_RANGE_END%' AND t.station_id = s.station_id ORDER BY t.tran_date SPOOL off quit 这是生成的脚本,但是脚本在执行到语句部分就卡住不动了
最新发布
03-21
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值