设置SQL*Plus的Autotrace

本文介绍如何在Oracle中配置Autotrace,并详细说明了如何通过控制Autotrace系统变量来定制报告的内容。

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

    Autotrace是SQL*Plus中的一个工具,可以显示所执行查询的解释计划以及所用的资源。配置Autotrace的步骤如下:

  • 创建plan_table表、建立同义词并授权给用户
  • 创建plustrace角色并授权给用户

具体步骤如下:

  • 创建plan_table表、建立同义词并授权给用户   
  1. cd [ORACLE_HOME]/rdbms/admin;
  2. 作为DBA登陆SQL*Plus;
  3. 运行@utlxplan;
  4. 运行Create public synonym plan_table for plan_table;
  5. 运行grant all on plan_table to public。
  • 创建plustrace角色 
  1. cd [ORACLE_HOME]/sqlplus/admin;
  2. 作为sys或sysdba登录SQL*Plus;
  3. 运行@plustrce;
  4. 运行grant plustrace to public。

通过控制Autotrace系统变量可以控制Autotrace报告的生产:

  • set autotrace off:不生产Autotrace报告,这是默认设置。
  • set autotrace on explain:Autotrace报告只显示优化器执行路径。
  • set autotrace on statistics:Autotrace报告只显示SQL语句的执行统计信息。
  • set autotrace on:Autotrace报告既包含优化器执行路径,又包括SQL语句的执行统计信息。
  • set autotrace traceonly:这与set autotrace on类似,但是不显示用户的查询输出(如果有的话)。
``` 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、付费专栏及课程。

余额充值