文章来源:http://blog.csdn.net/leshami/article/details/6866925

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

    有关执行计划中各字段模块的描述请参考: 执行计划中各字段各模块描述有关由SQL语句来获取执行计划请参考:     使用 EXPLAIN PLAN 获取SQL语句执行计划有关使用autotrace来获取执行计划请参考: 启用 AUTOTRACE 功能有关dbms_xplan之display函数请参考:     dbms_xplan之display函数的使用

一、display_cursor函数用法
1、display_cursor函数语法
[sql] view plain copy

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和memstatsrun_stats_last 等同于iostats last。只能用于oracle 10g R1run_stats_tot  等同于iostats。只能用于oracle 10g R1                  

二、演示使用display_cursor函数获取执行计划 
1、当前数据库版本以及加载执行计划到库缓存 
[sql] view plain copy

SQL> select * from v$version where rownum<2;                        BANNER
----------------------------------------------------------------
Oracle Database 10g Release 10.2.0.3.0 - 64bit Production           

SQL> SELECT ename,dname,loc                                         2  FROM   emp e, dept d                                           3  WHERE  e.deptno = d.deptno                                     4  AND    e.empno  = 7788;                                        ENAME      DNAME          LOC
---------- -------------- -------------
SCOTT      RESEARCH       DALLAS                                    2、查看真实的执行计划              

[sql] view plain copy

/*----------------不传递任何参数给display_cursor函数,显示当前会话最后一条SQL语句的执行计划-------------*/
/**************************************************/
/* Author: Robinson Cheng                         */
/* Blog:   http://blog.csdn.net/robinson_0612     */
/* MSN:    robinson_0612@hotmail.com              */
/* QQ:     645746311                              */
/**************************************************/
SQL> select * from table(dbms_xplan.display_cursor(null,null));                                                         PLAN_TABLE_OUTPUT
------------------------------------------------------------------------------------------
SQL_ID  a67wqmkfb9j65, child number 0
-------------------------------------
SELECT ename,dname,loc FROM   emp e, dept d WHERE  e.deptno = d.deptno AND
e.empno  = 7788                                                                                                         Plan hash value: 2385808155                                                                                             ----------------------------------------------------------------------------------------
| Id  | Operation                    | Name    | Rows  | Bytes | Cost (%CPU)| Time     |
----------------------------------------------------------------------------------------
|   0 | SELECT STATEMENT             |         |       |       |     3 (100)|          |
|   1 |  NESTED LOOPS                |         |     1 |    63 |     3   (0)| 00:00:01 |
|   2 |   TABLE ACCESS BY INDEX ROWID| EMP     |     1 |    33 |     2   (0)| 00:00:01 |
|*  3 |    INDEX UNIQUE SCAN         | PK_EMP  |     1 |       |     1   (0)| 00:00:01 |
|   4 |   TABLE ACCESS BY INDEX ROWID| DEPT    |   409 | 12270 |     1   (0)| 00:00:01 |
|*  5 |    INDEX UNIQUE SCAN         | PK_DEPT |     1 |       |     0   (0)|          |
----------------------------------------------------------------------------------------                                Predicate Information (identified by operation id):
---------------------------------------------------                                                                     3 - access("E"."EMPNO"=7788)                                                                                         5 - access("E"."DEPTNO"="D"."DEPTNO")                                                                                /*------------------- 获得SQL语句的SQL_ID,可以看出此SQL_ID与上面显示的执行计划中的SQL_ID一致 ----------*/
SQL> select sql_id,address,plan_hash_value,hash_value,child_number from v$sql                                           2  where sql_text like '%SELECT ename%' and sql_text not like '%from v$sql%';                                         SQL_ID        ADDRESS          PLAN_HASH_VALUE HASH_VALUE CHILD_NUMBER
------------- ---------------- --------------- ---------- ------------
a67wqmkfb9j65 0000000091DBFBC8      2385808155 2629092549            0                                                  /*-------------- 传递SQL_ID以及format参数,并配合修饰符控制执行计划的输出 ------------------------*/
SQL> select * from table(dbms_xplan.display_cursor('a67wqmkfb9j65',null,'typical -predicate -rows'));                   PLAN_TABLE_OUTPUT
------------------------------------------------------------------------------------
SQL_ID  a67wqmkfb9j65, child number 0
-------------------------------------
SELECT ename,dname,loc FROM   emp e, dept d WHERE  e.deptno = d.deptno
AND    e.empno  = 7788                                                                                                  Plan hash value: 2385808155                                                                                             --------------------------------------------------------------------------------
| Id  | Operation                    | Name    | Bytes | Cost (%CPU)| Time     |
--------------------------------------------------------------------------------
|   0 | SELECT STATEMENT             |         |       |     3 (100)|          |
|   1 |  NESTED LOOPS                |         |    63 |     3   (0)| 00:00:01 |
|   2 |   TABLE ACCESS BY INDEX ROWID| EMP     |    33 |     2   (0)| 00:00:01 |
|   3 |    INDEX UNIQUE SCAN         | PK_EMP  |       |     1   (0)| 00:00:01 |
|   4 |   TABLE ACCESS BY INDEX ROWID| DEPT    | 12270 |     1   (0)| 00:00:01 |
|   5 |    INDEX UNIQUE SCAN         | PK_DEPT |       |     0   (0)|          |
--------------------------------------------------------------------------------                                            3、查看真实执行计划并获得统计信息
            前提条件
                    设置参数statistics_level为all,可以基于session级别以及实例级别
                    或者启用gather_plan_statistics提示      

[sql] view plain copy

/*-------------查看实例参数statistics_level的值,并在会话级别将其设定为all  ---------*/
SQL> show parameter statistics_le                                                                                        NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
statistics_level                     string      ALL                                                                     SQL> alter session set statistics_level=all;                                                                             Session altered.                                                                                                         SQL> select e.ename,e.sal,s.grade                                                                                        2  from emp e                                                                                                          3  join salgrade s                                                                                                     4  on e.sal between losal and hisal                                                                                    5  and e.deptno = 20;                                                                                                  ENAME             SAL      GRADE
---------- ---------- ----------
SCOTT            3000          4
FORD             3000          4
JONES            2975          4
ADAMS            1100          1
SMITH             800          1                                                                                         /*------- 执行上述SQL语句后获得其真实的执行计划,使用了iostats last -predicate -note 修饰符控制显示输出 -----*/
SQL> set pagesize 0
SQL> select * from table(dbms_xplan.display_cursor(null,null,'iostats last -predicate -note'));
SQL_ID  243b0tpjxj6wv, child number 0
-------------------------------------
select e.ename,e.sal,s.grade from emp e join salgrade s on e.sal between losal and
hisal and e.deptno = 20                                                                                                  Plan hash value: 4204027666                                                                                              -------------------------------------------------------------------------------------------
| Id  | Operation            | Name     | Starts | E-Rows | A-Rows |   A-Time   | Buffers |
-------------------------------------------------------------------------------------------
|   1 |  MERGE JOIN          |          |      1 |      1 |      5 |00:00:00.01 |      14 |
|   2 |   SORT JOIN          |          |      1 |      5 |      5 |00:00:00.01 |       7 |
|   3 |    TABLE ACCESS FULL | EMP      |      1 |      5 |      5 |00:00:00.01 |       7 |
|   4 |   FILTER             |          |      5 |        |      5 |00:00:00.01 |       7 |
|   5 |    SORT JOIN         |          |      5 |      5 |     14 |00:00:00.01 |       7 |
|   6 |     TABLE ACCESS FULL| SALGRADE |      1 |      5 |      5 |00:00:00.01 |       7 |
-------------------------------------------------------------------------------------------                              /*---------------- 修改会话级别的参数statistics_level为typical并验证修改结果 ----------------*/
SQL> alter session set statistics_level=typical;                                                                         SQL> col name format a40
SQL> col value format a25
SQL> col display_value format a25
SQL> select name, value, display_value, isses_modifiable                                                                 2  from v$parameter                                                                                                    3  where isses_modifiable = 'TRUE'                                                                                     4  and name like '%&input_name%';
Enter value for input_name: statistics_level
old   4: and name like '%&input_name%'
new   4: and name like '%statistics_level%'                                                                              NAME                                     VALUE                     DISPLAY_VALUE             ISSES
---------------------------------------- ------------------------- ------------------------- -----
statistics_level                         TYPICAL                   TYPICAL                   TRUE                        /*-------- 使用提示gather_plan_statistics,并获得其真实执行计划,使用了allstats -rows修饰符控制显示输出 ---*/
SQL> set pagesize 180
SQL> SELECT /*+ gather_plan_statistics */ ename,dname,loc                                                                2  FROM   emp e, dept d                                                                                                3  WHERE  e.deptno = d.deptno                                                                                          4  AND    d.deptno=20 ORDER BY 1,2,3;                                                                                  ENAME      DNAME          LOC
---------- -------------- -------------
ADAMS      RESEARCH       DALLAS
FORD       RESEARCH       DALLAS
JONES      RESEARCH       DALLAS
SCOTT      RESEARCH       DALLAS
SMITH      RESEARCH       DALLAS                                                                                         SQL> select * from table(dbms_xplan.display_cursor(null,null,'allstats -rows'));                                         PLAN_TABLE_OUTPUT
-------------------------------------------------------------------------------------------------
SQL_ID  d2hh42yzqqjz7, child number 0
-------------------------------------
SELECT /*+ gather_plan_statistics */ ename,dname,loc FROM   emp e, dept d WHERE  e.deptno = d.deptno AND
d.deptno=20 ORDER BY 1,2,3                                                                                               Plan hash value: 3339094711                                                                                              ---------------------------------------------------------------------------------------------------------------------
| Id  | Operation                     | Name    | Starts | A-Rows |   A-Time   | Buffers |  OMem |  1Mem |  O/1/M   |
---------------------------------------------------------------------------------------------------------------------
|   1 |  SORT ORDER BY                |         |      1 |      5 |00:00:00.01 |       9 |  2048 |  2048 |     1/0/0|
|   2 |   NESTED LOOPS                |         |      1 |      5 |00:00:00.01 |       9 |       |       |          |
|   3 |    TABLE ACCESS BY INDEX ROWID| DEPT    |      1 |      1 |00:00:00.01 |       2 |       |       |          |
|*  4 |     INDEX UNIQUE SCAN         | PK_DEPT |      1 |      1 |00:00:00.01 |       1 |       |       |          |
|*  5 |    TABLE ACCESS FULL          | EMP     |      1 |      5 |00:00:00.01 |       7 |       |       |          |
---------------------------------------------------------------------------------------------------------------------    Predicate Information (identified by operation id):
---------------------------------------------------                                                                      4 - access("D"."DEPTNO"=20)                                                                                           5 - filter("E"."DEPTNO"=20)                                                                                           Note
-----                                                                                                                    - dynamic sampling used for this statement                                                                            

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

本文转自xiaocao1314051CTO博客,原文链接: http://blog.51cto.com/xiaocao13140/2056436,如需转载请自行联系原作者

dbms_xplan之display_cursor函数的使用相关推荐

  1. PL/SQL -- 动态SQL调用包中函数或过程

    动态SQL主要是用于针对不同的条件或查询任务来生成不同的SQL语句.最常用的方法是直接使用EXECUTE IMMEDIATE来执行动态SQL语句字符串或字符串变量.但是对于系统自定义的包或用户自定的包 ...

  2. 数据导入时遭遇 ORA-01187 ORA-01110

    最近的数据导入(IMP)时碰到了ORA-01187 ORA-01110 错误,由于这个数据库是使用热备恢复过来的,且恢复也是成功的,因为数据库能够成功open,那到底是哪里有遗漏呢?如你有类似的问题, ...

  3. 执行计划中各字段各模块描述

    在SQL语句的执行计划中,包含很多字段项和很多模块,其不同字段代表了不同的含义且在不同的情形下某些字段.模块显示或不显示,下 面的描述给出了执行计划中各字段的含义以及各模块的描述. 有关执行计划中各字 ...

  4. Oracle AWR 阙值影响历史执行计划

    最近有网友提到为什么在dba_hist_sql_plan中无法查看到sql语句的历史执行计划,对于这个问题是由于缺省情况下,Oracle 设定的阙值并非捕获所有的sql语句,所以无法看到某些sql历史 ...

  5. NULL 值与索引(一)

    NULL值是关系数据库系统布尔型(true,false,unknown)中比较特殊类型的一种值,通常称为UNKNOWN或空值,即是未知的,不确定的.由于 NULL存在着无数的可能,因此NULL值也不等 ...

  6. INDEX FULL SCAN vs INDEX FAST FULL SCAN

    INDEX FULL SCAN 与 INDEX FAST FULL SCAN两个长相差不多,乃是一母同胞,因此既有其共性,也有其个性.两者来说其共性是不用扫描表而是通过索引就可以直接返回所需要的所有数 ...

  7. Oracle OWI 等待事件历史视图及相关视图

    Oracle提供的等待事件视图使得我们可以获取指定session以及实例级别等待事件的详细信息,这些视图分别是v$session_wait,v$session_event,以及v$system_eve ...

  8. Oracle执行计划显示

    生成和显示SQL语句的执行计划,是大多数DBA.SQL开发人员以及性能优化专家经常做的工作,因为执行计划能够提供SQL语句性能相关的信息.执行计划解释了SQL语句执行的详细过程,这个过程记录了一系列的 ...

  9. plan explorer mysql_plan explorer支持oracle吗

    展开全部 1.SQL语句的执行62616964757a686964616fe58685e5aeb931333361326365计划 使用EXPLAIN PLAN语句来确定Oracle数据库下指定SQL ...

最新文章

  1. Spring Boot日志学习记录【2】
  2. 女大男9岁 我们不可以么
  3. 百度痞哥:百度贴吧的回帖为什么没做点赞功能?
  4. mandatory oracle 字段,Oracle 数据库需要在2019年April之前Mandatory升级的说明
  5. ADB server didn't ACK
  6. ubuntu nginx安装
  7. Shell脚本IF条件判断和判断条件总结
  8. csgo手机上看demo_《CSGO》观看游戏DEMO方法 怎么观看游戏DEMO
  9. Python中一个非常高效的json对比库--deepdiff
  10. vmware输入序列号老是不能注册问题
  11. mysql64官网下教程_最新版MySQL 8.0.22下载安装超详细教程(Windows 64位)
  12. 交换机与交换机之间连接用五类线还是六类线?
  13. 如何把PPT文件压缩到最小
  14. html在线人数统计代码,做一个简单的网站统计和在线人数统计
  15. 《孤独的根号三》 中英文对照
  16. 合宙Air105 + GC032A摄像头驱动显示教程说明
  17. Android 12.0系统默认设置屏幕永不息屏
  18. GPS手机射频的一些测试项目
  19. uni-app实现拼多多倒计时拼团
  20. 白杨SEO:SEO转型难吗?SEO如何转型ASO(应用商店搜索优化)?

热门文章

  1. bootstrap jquery alert_bootstrap第七课
  2. applicationproperties不是小叶子_三角梅整株叶子发黄从这里找原因,早解决早生长!...
  3. 颜色协调模型Color Harmoniztion
  4. volatile的适用场景
  5. 正則表達式,终极使用!3个工具,搞定一切
  6. android基础组件----Button的使用
  7. EasyUI加载外部页面需要使用html片段
  8. C语言经典面试题目(转的,不过写的的确好!)
  9. 8.16——熟悉安装linux系统
  10. Shiro 登录、退出、校验是否登录涉及到的Session和Cookie