如何啟用sqlplus的auto trace功能(zt)

tolywang發表於2008-02-25

透過以下方法可以把Autotrace的許可權授予Everyone

如果你需要限制Autotrace許可權,可以把對public的授權改為對特定user的授權。

[@more@]

D:oracleora92>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> @?rdbmsadminutlxplan

表已建立。

SQL> create public synonym plan_table for plan_table;

同義詞已建立。

SQL> grant all on plan_table to public ;

授權成功。

SQL> @?sqlplusadminplustrce
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>

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/35489/viewspace-999948/,如需轉載,請註明出處,否則將追究法律責任。

相關文章