程序员人生 网站导航

最权威Oracle获取SQL执行计划大全

栏目:数据库应用时间:2015-03-20 08:57:57

该文档为根据相干资料整理、总结而成,主要讲授Oracle数据库中,获得SQL语句履行计划的最权威、最正确的方法、步骤,另外,还详细说明了每种方法中可选项的意义及使用方法,以方便大家和自己平常工作中查阅使用,因本人未发现本博客支持附件上传功能,需要PDF文件格式的朋友可向我要,也可到群里下载,转载请注明出处

1、查询v$sql_plan:

SQL> col "Query Plan_Table" format a100

SQL> select id,lpad(' ', 2*(level⑴))||operation||''||options||' '||object_name||' '||decode(id, 0, 'Cost='||cost) "QueryPlan_Table"

       fromv$sql_plan

       startwith id = 0

        andsql_id = '&&sql_id'

        andplan_hash_value = &&plan_hash

    connect byprior id = parent_id

        andsql_id = '&&sql_id'

        andplan_hash_value = &&plan_hash;

--注::SQL_ID可查v$sqltext和dba_hist_sqltext,也可通过其他途径取得。

 

2、通过包DBMS_XPLAN

1)DISPLAY

SQL>explain plan for select * from t_users whereuser_id='TEST';

SQL>select * from table(dbms_xplan.display());

SQL>select * fromtable(dbms_xplan.display(null,null,'BASIC ROWS BYTES'));

--注:

1.TABLE_NAME:存储查询计划的表名,默许值为PLAN_TABLE。

2.STATEMENT_ID :SQL 语句ID。可在履行ExplainPlan 命令时,通过SetStatement_

id 子句来指定。如为NULL,则取最近1条被解释的语句。

3.FORMAT:输出格式。在DISPLAY 函数中,有以下预定义格式选:

1)'BASIC' :基本格式。输出的内容最少,仅输出查询计划中每一个操作的ID、名称和选项及操作对象名。

2)'TYPICAL':典型格式。除基本格式中的内容外,还输出每一个操作的记录行数、

字节数、代价和时间,和相干的提示信息(如远程SQL、优化器建议等)。如

存在谓词,还输出每一个操作中的过滤条件和访问条件。另外,如触及分区表,还输出分区裁剪信息;如触及并行查询,还输出并行操作信息(如表队列信息、并行查询散布方式等)。为默许格式。

3)'SERIAL':串行履行格式。这类格式和典型格式的输出内容基本1致,不同的地方在于,对并行查询,它不会输出相干的并行内容。

4)'ALL':完全格式。输出的内容相对完全。除典型格式的内容之外,还会输出字段投影信息和别名信息。

另外,用户还可通过在格式化字符串中添加或屏蔽1些关键词进行细化输出,

例如:“BASICROWS”,“TYPICAL-PREDICATE”等

1)ROWS:优化器估算出的记录行数;

2)BYTES:优化器估算出的字节数;

3)COST:优化器估算出的代价;

4)PARTITION:分区裁剪;

5)PARALLEL:并行查询;

6)PREDICATE:谓词;

7)PROJECTION:字段投射;

8)ALIAS:别名;

9)REMOTE:散布式查询信息;

10)NOTE:相干注释信息。

2)DISPLAY_CURSOR

SQL>select /*+gather_plan_statistics*/* fromt_users where user_id='TEST';

SQL>select * fromtable(dbms_xplan.display_cursor(null,null,'BASIC LAST ALLSTATS'));

--注:

1.DISPLAY_CURSOR 函数可以显示内存中1个或多个游标的履行计划;

2.用户须对视图V$SQLV、$SQL_PLAN 和V$SQL_PLAN_STATISTICS_ALL 的SELECT有权限;

3.参数:

1)SQL_ID:如果没有指定SQL_ID(指定NULL),则默许会显示当前会话中最后1条履行的SQL 语句。

2)CURSOR_CHILD_NO:语句的子游标序号,如果不指定,则会显示该语句的所有子游标的履行计划。

3)FORMAT:格式化控制字符串。DISPLAY 函数的格式化控制字符串的所有选项都适用于DISPLAY_CURSOR 函数。如运行语句时通过GATHER_PLAN_STATISTICS或设置系统参数STATISTICS_LEVEL 为“ALL”搜集语句运行的性能统计数据,则在细化选项中还有额外的选项,以选择是不是输出这些数据。

4)IOSTATS:是不是输出计划的输入输出(IO)统计数据;

5)MEMSTATS :在启用了PGA 自动管理的情况下,是不是输出计划的输入内存统计数据(内存使用量、内存读次数等);

6)ALLSTATS:包括了IOSTATS和MEMSTATS 的全部内容;

7) LAST :以上3个选项输出的是该游标所有履行所产生的数据的总和。也可增加LAST选项以限定仅显示最后1次运行的统计数据。

另外,还有1些选项可用于该函数的输出控制:

8)'ADVANCED' :高级格式。高级格式除会输出完全格式中的所有内容外,还会视情况输出绑定变量窥视信息和计划概要信息;

9) OUTLINE:是不是以提示方式显示计划概要;

10)PEEKED_BINDS:是不是显示绑定变量窥视信息;

11)BUFFSTATS:是不是显示内存读次数(包括1致性读和当前读次数),该信息为IOSTATS 的1部份;

12)PLAN_HASH:是不是显示计划的哈希值,该选项一样适用于DISPLAY函数。

3)DISPLAY_AWR

SQL>select sql_id, to_char(substr(sql_text,0,2000))

      fromdba_hist_sqltext

     whereupper(sql_text) like 'SELECT * FROM TEST%';

SQL>select * fromtable(dbms_xplan.display_awr('&sql_id'));

--注:

1.DISPLAY_AWR 函数显示存储在AWR历史数据的履行计划。

2.须对以下视图有SELECT权限:DBA_HIST_SQL_PLAN 和DBA_HIST_SQLTEXT。

3.参数:

1)SQL_ID :可以从DBA_HIST_SQL_PLAN.SQL_ID或DBA_HIST_SQLTEXT.SQL_ID 取得,该参数必须指定非空值,没有默许值;

2)PLAN_HASH_VALUE :如果该参数未指定或为NULL,则会显示语句的所有履行计划;

3)DB_ID:指定显示哪一个数据库的履行计划,默许为本地数据库ID。页可将其他数据库的AWR导入本地库进行分析。

4)FORMAT:格式化控制字符串。与DISPLAY的相同选项类似。

 

4)DISPLAY_SQLSET

SQL>declare

2 ss_name varchar2(60);

3 begin

4 ss_name :=dbms_sqltune.create_sqlset();

5 dbms_sqltune.capture_cursor_cache_sqlset(ss_name,600,100);

6 dbms_output.put_line(ss_name);

7 end;

8 /

SQL>select sqlset_name,sql_id,sql_text fromDBA_SQLSET_STATEMENTS where upper(sql_text)

like 'SELECT * FROM TEST%';

SQL>select * fromtable(dbms_xplan.display_sqlset('STS_6','abcdefg',null,'BASIC ROWS COST'));

--注:

1.DISPLAY_SQLSET函数显示存储在1个SQL调优集中的语句的履行计划。

2.参数:

1)SQLSET_NAME:SQL 集的名称。每一个SQL 集都有1个单独的名称(可在创建时

用户指定,也可系统自动生成),需指定从哪一个SQL集中读取和显示语句的履行计划,该参数没有默许值,必须指定;

2)SQL_ID :可从USER/DBA/ALL_SQLSET_PLANS.SQL_ID取得,该参数必须指定非空值,没有默许值;

3)PLAN_HASH_VALUE:如果未指定或为NULL,则会显示语句的所有履行计划;

4)FORMAT:格式化控制字符串。与DISPLAY的FORMAT 选项相同;

5)SQLSET_OWNER:SQL集的所有者,默许为当前用户名。

5)DISPLAY_SQL_PLAN_BASELINE

SQL>select * fromtable(dbms_xplan.display_sql_plan_baseline(sql_handle =>

'SYS_SQL_66cc81707e560a32'));

--注:

1.DISPLAY_SQL_PLAN_BASELINE 函数显示存储在数据字典当中SQL 履行计划基线的计划。

2.参数:

1)SQL_HANDLE:履行计划基线所属SQL的句柄名称,由Oracle在创建或载入履行计划到基线当中时自动生成,可以通过视图dba_sql_plan_baselines查询,默许为NULL;

2)PLAN_NAME :履行计划基线中某个履行计划的名称,由Oracle 创建或载入履行计划到基线当中时自动生成,可以通过视图dba_sql_plan_baselines查询,默许为NULL;

3)FORMAT :格式化控制字符串。DISPLAY_SQLSET 函数的格式化选项与DISPLAY

的选项相同。

4)当SQL_HANDLE和PLAN_NAME 都为空时,显示所有基线数据中的全部履行计划。

 

3、AUTOTRACE

1)配置test用户使用autot

SQL>conn sys/sys as sysdba

SQL>@?/SQLPLUS/ADMIN/PLUSTRCE.SQL

SQL>grant plustrace totest;

2)使用方法

1.SET AUTOTRACE ON:打开AUTOTRACE,并输出所有内容,包括语句本身的查询结果、履行计划,和性能统计数据。

2.SET AUTOTRACE ON EXPLAIN :打开AUTOTRACE,并输出语句本身的查询结果和履行计划,不输出性能统计数据。

3.SET AUTOTRACE ON STATISTICS :打开AUTOTRACE,并输出语句本身的查询结果和性能统计数据,不输出履行计划。

4.SET AUTOTRACE TRACE :打开AUTOTRACE,并输出履行计划和性能统计数据,不输出语句本身的查询结果。

5.SET AUTOTRACE TRACE EXPLAIN :打开AUTOTRACE,并输出履行计划,不输出语句本身的查询结果和性能统计数据。

6.SET AUTOTRACE TRACESTATISTICS:打开AUTOTRACE,并输出性能统计数据,不输出语句本身的查询结果和履行计划。

7.SET AUTOTRACE OFF:关闭AUTOTRACE。

 

4、其他方法

1)SQL_TRACE(或10046 跟踪事件):该方法会在跟踪文件里显示履行计划及相干统计信息:

SQL>alter session set sql_trace=true;

SQL>select * from t_users where user_id=’TEST’;

SQL>alter session set sql_trace=false;

SQL>select distinct spid from v$process p,v$session s, v$mystat m where p.addr=s.paddr and s.sid=m.sid;

SQL>show parameter user_dump_dest

SQL>ed/home/oracle/admin/ora10g/udump/ora10g_ora_sid.trc

2)OPTIMIZER_TRACE(或10053 跟踪事件):该方法会在跟踪文件里记录优化器分析选择履行计划的进程:

SQL>alter session set"_optimizer_trace"=ALL;

SQL>explain plan for select * from t_users whereusername=’TEST’;

SQL>alter session set"_optimizer_trace"=NONE;

SQL>select distinct spid from v$process p,v$session s, v$mystat m where p.addr=s.paddr and s.sid=m.sid;

SQL>ed/home/oracle/admin/ora10g/udump/ora10g_ora_sid.trc

 



------分隔线----------------------------
------分隔线----------------------------

最新技术推荐