oracle 11G dbms_xplan包的使用

一、dbms_xplan.display的使用

    1.  explain  plan for    一定要加上这个执行计划

        select count(*)  from dual;

   2.select  * from  table(dbms_xplan.display);  之后就可以看到刚才那个语句的执行计划。

 

   dbms_xplan.display的格式

  DBMS_XPLAN.DISPLAY( table_name IN VARCHAR2 DEFAULT 'PLAN_TABLE',

                                                 statement_id IN VARCHAR2 DEFAULT NULL,

                                                 format IN VARCHAR2 DEFAULT 'TYPICAL',  

                                                 filter_preds IN VARCHAR2 DEFAULT NULL);

   table_name   
              指定计划表的名字,缺省值为'PLAN_TABLE'.
        statement_id 
                SQL语句的ID号,是在生成执行计划时使用set statement_id命令设定的值,默认值为NULL,当使用默认值时,将显示最近
                插入计划表中的执行计划(filter_preds参数的值为空时)
        format  
                用于控制display函数输出的内容。其常用取值为basic,typical,serial,all,advanced。其中typical为缺省值
                除了上述几个取值外,还可以配合一些额外的修饰符来显示不同的内容。如:
                      alias、bytes、cost、note、outline、parallel、paration、predicate等
                常用取值组合修饰符的例子:
                        basic +predicate、basic +outline(需要某个修饰符使用"+"号来连接)
                        typical -bytes、typical +alias -bytes -cost(不需要某个修饰符使用"-"号来连接)
                        注:"+"号与"-"号前面应保留空格
        filter_preds
                过滤谓词。用于过滤从plan_table表中返回的记录。当该值为NULL时,执行计划显示最近插入计划表中的执行计划。
                        如:filter_preds=>'plan_id = 223'

例子:

    一、  SQL> EXPLAIN PLAN SET STATEMENT_ID='TSH' FOR 
          2  SELECT * 
          3  FROM   emp e, dept d 
          4  WHERE  e.deptno = d.deptno 
          5  AND    e.ename  = 'SMITH'; 
 
      SQL> SELECT *  
         2  FROM   TABLE(DBMS_XPLAN.DISPLAY('PLAN_TABLE','TSH','BASIC'));  

        select * from table(dbms_xplan.display(null,'TSH','basic +predicate'));  

  二、select statement_id,plan_id from plan_table where rownum<2;

         select * from table(dbms_xplan.display(null,null,'advanced -bytes','plan_id = 223'));  
总结
        1、display函数仅仅针对预估的执行计划,而不是实际的执行计划
        2、display函数显示了预估的执行计划且显示格式灵活,可以以不同的输出格式呈现
        3、当所有参数为null的情况下,显示执行计划表中(缺省为plan_table)最后一条语句的执行计划
        4、尽管可以通过SQL语句查询plan_table来获取执行计划,建议直接使用display函数,这足够说明一切问题   
        5、当SQL语句中使用了绑定变量时,由explain plan获得的执行计划是不可靠的

dbms_xplan.display_cursor的使用说明

   DBMS_XPLAN包中display_cursor函数不同于display函数,display_cursor用于显示SQL语句的真实的执行计划,在大多数情况下,显示真实
的执行计划有助于更好的分析SQL语句的全过程,尤其是运行此SQL语句实时的I/O开销。通过对比预估的I/O与真实的I/O开销来判断SQL语句所存
在问题,如缺少统计信息,SQL语句执行的次数,根据实际中间结果集的大小来选择合适的连接方式等。

  1、display_cursor函数语法
 
DBMS_XPLAN.DISPLAY_CURSOR(                        
 sql_id        IN  VARCHAR2  DEFAULT  NULL,       
 child_number  IN  NUMBER    DEFAULT  NULL,       
 format        IN  VARCHAR2  DEFAULT  'TYPICAL'); 
2、display_cursor函数参数描述
        sql_id
                指定位于库缓存执行计划中SQL语句的父游标。默认值为null。当使用默认值时当前会话的最后一条SQL语句的执行计划将被返回
                可以通过查询V$SQL 或V$SQLAREA的SQL_ID列来获得SQL语句的SQL_ID。
        child_number
                指定父游标下子游标的序号。即指定被返回执行计划的SQL语句的子游标。默认值为0。如果为null,则sql_id所指父游标下所有子游标
                的执行计划都将被返回。
        format
                控制SQL语句执行计划的输出部分,即哪些可以显示哪些不显示。使用与display函数的format参数与修饰符在这里同样适用。
                除此之外当在开启statistics_level=all时或使用gather_plan_statistics提示可以获得执行计划中实时的统计信息
                有关详细的format格式描述请参考:dbms_xplan之display函数的使用 中format参数的描述
 
        下面给出启用统计信息时format新增的修饰符
                iostats   控制I/O统计的显示
                last      默认,显示所有执行计算过的统计。如果指定该值,则只显示最后一次执行的统计信息
                memstats  控制pga相关统计的显示
                allstats  此为iostats memstats的快捷方式,即allstats包含了iostats和memstats
                run_stats_last 等同于iostats last。只能用于oracle 10g R1
                run_stats_tot  等同于iostats。只能用于oracle 10g R1    

例子:1、select * from dual;

                   select * from table(dbms_xplan.display_cursor(null,null));  不传递任何参数给display_cursor函数,显示当前会话最后一条SQL语句的执行计划

            2、 select sql_id,address,plan_hash_value,hash_value,child_number from v$sql                                          
                   where sql_text like '%SELECT ename%' and sql_text not like '%from v$sql%';(获得SQL语句的SQL_ID,可以看出此SQL_ID与上面显示的执行计划中的SQL_ID);

                  select * from table(dbms_xplan.display_cursor('a67wqmkfb9j65',null,'typical -predicate -rows'));                  
               查看实例参数statistics_level的值,并在会话级别将其设定为all     show parameter statistics_level的参数值。不同的值对显示的出来的东西也不 样 。                   

  总结
                    1、与display函数不同,display_cursor显示的为真实的执行计划
                    2、对于format参数,使用与display函数的各个值,同样适用于display_cursor函数
                   3、当statistics_level为all或使用gather_plan_statistics提示可以获得执行时的统计信息
                   4、根据真实与预估的统计信息可以初步判断SQL效率低下的原因,如统计信息的准确性、主要的开销位于那些步骤等   

                                                                          

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值