eygle.com   eygle.com
eygle.com eygle
eygle.com  
 

« 关于数据文件头信息记录 | Blog首页 | 使用DBMS_SUPPORT包 »

如何启用sqlplus的AutoTrace功能

通过以下方法可以把Autotrace的权限授予Everyone,

如果你需要限制Autotrace权限,可以把对public的授权改为对特定user的授权。

 

 

D:\oracle\ora92>sqlplus /nolog

SQL*Plus: Release 9.2.0.1.0 - Production on 星期二 6月 3 15:16:03 2003

Copyright (c) 1982, 2002, Oracle Corporation. All rights reserved.

SQL> connect sys as sysdba
请输入口令:
已连接。
SQL> @?\rdbms\admin\utlxplan

表已创建。

SQL> create public synonym plan_table for plan_table;

同义词已创建。

SQL> grant all on plan_table to public ;

授权成功。

SQL> @?\sqlplus\admin\plustrce
SQL>
SQL> drop role plustrace;
drop role plustrace
*
ERROR 位于第 1 行:
ORA-01919: 角色'PLUSTRACE'不存在

SQL> create role plustrace;

角色已创建
SQL>
SQL> grant select on v_$sesstat to plustrace;

授权成功。

SQL> grant select on v_$statname to plustrace;

授权成功。

SQL> grant select on v_$session to plustrace;

授权成功。

SQL> grant plustrace to dba with admin option;

授权成功。

SQL>
SQL> set echo off

 

DBA用户首先被授予了plustrace角色,然后我们可以把plustrace授予public

这样所有用户都将拥有plustrace角色的权限.

 

 

SQL> grant plustrace to public ;

授权成功。


然后我们就可以使用AutoTrace的功能了.

 

 

SQL> connect eqsp/eqsp
已连接。
SQL> set autotrace on
SQL> set timing on
SQL>

 

 

关于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 traceonly
SQL> select table_name from user_tables;

已选择98行。

已用时间: 00: 00: 00.04

Execution Plan
----------------------------------------------------------
0 SELECT STATEMENT Optimizer=CHOOSE
1 0 NESTED LOOPS
2 1 NESTED LOOPS (OUTER)
3 2 NESTED LOOPS (OUTER)
4 3 NESTED LOOPS (OUTER)
5 4 NESTED LOOPS (OUTER)
6 5 NESTED LOOPS
7 6 TABLE ACCESS (BY INDEX ROWID) OF 'OBJ$'
8 7 INDEX (RANGE SCAN) OF 'I_OBJ2' (UNIQUE)
9 6 TABLE ACCESS (CLUSTER) OF 'TAB$'
10 9 INDEX (UNIQUE SCAN) OF 'I_OBJ#' (NON-UNIQUE)
11 5 TABLE ACCESS (BY INDEX ROWID) OF 'OBJ$'
12 11 INDEX (UNIQUE SCAN) OF 'I_OBJ1' (UNIQUE)
13 4 INDEX (UNIQUE SCAN) OF 'I_OBJ1' (UNIQUE)
14 3 TABLE ACCESS (CLUSTER) OF 'USER$'
15 14 INDEX (UNIQUE SCAN) OF 'I_USER#' (NON-UNIQUE)
16 2 TABLE ACCESS (CLUSTER) OF 'SEG$'
17 16 INDEX (UNIQUE SCAN) OF 'I_FILE#_BLOCK#' (NON-UNIQUE)
18 1 TABLE ACCESS (CLUSTER) OF 'TS$'
19 18 INDEX (UNIQUE SCAN) OF 'I_TS#' (NON-UNIQUE)

 

Statistics
----------------------------------------------------------
0 recursive calls
0 db block gets
1389 consistent gets
0 physical reads
0 redo size
2528 bytes sent via SQL*Net to client
569 bytes received via SQL*Net from client
8 SQL*Net roundtrips to/from client
0 sorts (memory)
0 sorts (disk)
98 rows processed

SQL>

 


-The End-


历史上的今天...
    >> 2010-06-18文章:
    >> 2008-06-18文章:
    >> 2007-06-18文章:
    >> 2006-06-18文章:
           柔嘉维则一周年
    >> 2005-06-18文章:
           Howl's.Moving.Castle

无觅

By eygle on 2004-06-18 14:31 | Comments (11) | FAQ | HowTo | 12 |

11 Comments

真是不错。tks

THANKS

不行呀!我按照你的步骤还是提示:
SQL> set autotrace on
Cannot SET AUTOTRACE
创建plan_table表及同义词、授权都成功(public)
plustrace用户也创建及sys授权都成功(public),
现在是不管我再sys还是再其他用户下都都不能使用set autotrace on.我oracle版本也是oracle9i,之前做过一次成功了,但不知道现在为何不成功?请教你我该如何处理这样的情况?谢谢了!

SYS用户可以使用么?

drop plan_table;
重新建一次试试呢?

SQL> @d:\oracle9i\ora92\rdbms\admin\utlxplan;

Table created

SQL>
SQL> create public synonym plan_table for plan_table;

Synonym created
SQL> grant all on plan_table to icdsc;--icdsc为一用户名

Grant succeeded
SQL> --drop role trace_rol;
SQL> create role trace_rol;

Role created
SQL> grant select on v_$sesstat to trace_rol;

Grant succeeded
SQL> grant select on v_$statname to trace_rol;

Grant succeeded
SQL> grant select on v_$session to trace_rol;

Grant succeeded
SQL> grant trace_rol to dba with admin option;

Grant succeeded
SQL> set echo off
SQL> grant trace_rol to icdsc;

Grant succeeded

SQL> set autotrace on
Cannot SET AUTOTRACE

SQL> connect icdsc/icdsc;
Connected to Oracle9i Enterprise Edition Release 9.2.0.1.0
Connected as icdsc

SQL> set autotrace on
Cannot SET AUTOTRACE


怎么建都不行,不知道错在哪,还望指点一二,多谢!

你用10046跟踪一下会话set autotrace on,看看跟踪文件里面记录了什么错误

SQL> alter session set events '10046 trace name context forever,level 12';

Session altered.

SQL> set autotrace on

是不是用PL/SQL连接不行,我在pl/sql dev连接时候到最后出现
SQL> set autotrace on
Cannot SET AUTOTRACE

而用系统连接进去就可以

pl/sql dev不支持这个功能。

今天在9.2.0.4.0上试验下了下,发现我的系统需要加上grant select on v_$mystat to plustrace;
才可以。

对于dba用户这样就可以查看执行计划了.但对于没有dba权限的用户,还需要grant select any dictionary to user_name;

不错,学习了


CopyRight © 2004~2020 云和恩墨,成就未来!, All rights reserved.
数据恢复·紧急救援·性能优化 云和恩墨 24x7 热线电话:400-600-8755 业务咨询:010-59007017-7040 or 7037 业务合作: marketing@enmotech.com