怎樣查看sql的執(zhí)行計劃||如何啟用AutoTrace 查看SQL執(zhí)行計劃

          怎樣查看sql的執(zhí)行計劃

          如何啟用AutoTrace 查看SQL執(zhí)行計劃

          通過以下方法可以把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> [b]@?\rdbms\admin\utlxplan[/b]
          表已創(chuàng)建。
          SQL> create public synonym plan_table for plan_table;
          同義詞已創(chuàng)建。
          SQL> grant all on plan_table to public ;
          授權成功。
          SQL>[b] @?\sqlplus\admin\plustrce[/b]
          SQL>
          SQL> drop role plustrace;
          drop role plustrace
          *
          ERROR 位于第 1 行:
          ORA-01919: 角色'PLUSTRACE'不存在
          SQL> create role plustrace;
          角色已創(chuàng)建
          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> [b]grant plustrace to public ;[/b]

          授權成功。
          然后我們就可以使用AutoTrace的功能了.


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


          關于Autotrace幾個常用選項的說明:
          SET AUTOTRACE OFF ---------------- 不生成AUTOTRACE 報告,這是缺省模式
          SET AUTOTRACE ON EXPLAIN ------ AUTOTRACE只顯示優(yōu)化器執(zhí)行路徑報告
          SET AUTOTRACE ON STATISTICS -- 只顯示執(zhí)行統(tǒng)計信息
          SET AUTOTRACE ON ----------------- 包含執(zhí)行計劃和統(tǒng)計信息
          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>

          posted on 2008-04-08 23:32 金家寶 閱讀(678) 評論(0)  編輯  收藏 所屬分類: oracle

          主站蜘蛛池模板: 合阳县| 定襄县| 建湖县| 锦屏县| 石棉县| 黑河市| 德昌县| 财经| 广水市| 靖远县| 犍为县| 吴堡县| 阿拉善左旗| 梓潼县| 麻江县| 红原县| 鹤壁市| 东至县| 新密市| 邵武市| 平原县| 黄浦区| 钟祥市| 常山县| 宁强县| 唐河县| 德兴市| 东乡族自治县| 桓仁| 福鼎市| 泾阳县| 泰州市| 西昌市| 全南县| 尼木县| 苗栗市| 石狮市| 安乡县| 老河口市| 弥渡县| 板桥市|