dbms_xplan之display_cursor函数的使用
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函数语法
- 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
二、演示使用display_cursor函数获取执行计划
1、当前数据库版本以及加载执行计划到库缓存
- 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、查看真实的执行计划
- /*----------------不传递任何参数给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提示
- /*-------------查看实例参数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效率低下的原因,如统计信息的准确性、主要的开销位于那些步骤等
转载:http://blog.csdn.net/leshami/article/details/6866925
dbms_xplan之display_cursor函数的使用的更多相关文章
- dbms_xplan的display_cursor查看执行计划
准备工作: SQL> conn sys/root as sysdba Connected. SQL> grant select on v_$sql_plan to scott; Grant ...
- PL/SQL --> 动态SQL调用包中函数或过程
动态SQL主要是用于针对不同的条件或查询任务来生成不同的SQL语句.最常用的方法是直接使用EXECUTE IMMEDIATE来执行动态SQL语句字符串或字符串变量.但是对于系统自定义的包或用户自定的包 ...
- Oracle SQL tuning 步骤
Oracle SQL tuning 步骤 SQL是的全称是Structured Query Language(结构化查询语言).SQL是一个在80年代中期被使用的工业标准数据库查询语言.不要把SQL语 ...
- VirtualBox 扩展包卸载或安装失败(VERR_ALREADY_EXISTS)
最近在卸载VirtualBox出现了无法卸载的错误.提示为Failed to install the extension. The installer failed with exit code 1: ...
- RAC环境下的堵塞(blocking blocked)
RAC环境下的堵塞不同于单实例情形,由于我们须要考虑到位于不同实例的session.也就是说之前查询的v$session,v$lock对应的应变化为全局范围来查找.本文提供了2个查询脚本,并给出实例演 ...
- Oracle 堵塞(blocking blocked)
堵塞是DBA常常碰到的情形,尤其是不良的应用程序设计的堵塞将导致性能严重下降直至数据库崩溃. 对DBA而言,有必要知道怎样定位到当前系统有哪些堵塞,究竟谁是堵塞者,谁是被堵塞者.本文对此给出了描写叙述 ...
- 通过dbms_xplan.display_cursor识别低效的执行计划
dbms_xplan.display_cursor定义: function display_cursor(sql_id varchar2 default null, ...
- dbms_xplan的display查看执行计划
DBMS_XPLAN包包括一系列函数,主要是用于显示SQL语句的执行计划,且不同的情形下使用不同的函数来显示,如预估的执行计划则使用 display函数,而实际的执行计划则是用display_curs ...
- 查看ORACLE的实际执行计划
ORACLE的执行计划分为预估执行计划和实际执行计划.其中,你用Toad.PL/SQL Developer.SQL Developer.EXPLAIN PLAN FOR或者SET ATUOTRACE ...
随机推荐
- HOG+SVM+INRIAPerson数据集代码
#include <iostream> #include <opencv2/core/core.hpp> #include <opencv2/highgui/highgu ...
- virtualenv 设置虚拟环境来运行不同版本的python
转自: http://pythonguidecn.readthedocs.io/zh/latest/dev/virtualenvs.html virtualenv 是一个创建隔绝的Python环境的 ...
- BZOJ3514: Codechef MARCH14 GERALD07加强版【LCT】【主席树】【思维】
Description N个点M条边的无向图,询问保留图中编号在[l,r]的边的时候图中的联通块个数. Input 第一行四个整数N.M.K.type,代表点数.边数.询问数以及询问是否加密. 接下来 ...
- .NET 中什么样的类是可使用 await 异步等待的?
我们已经知道 Task 是可等待的,但是去看看 Task 类的实现,几乎找不到哪个基类.接口或者方法属性能够告诉我们与 await 相关. 而本文将探索什么样的类是可使用 await 异步等待的? D ...
- Hadoop storm大数据分析 知识体系结构
最近工作工作有用到hadoop 和storm,最近看到一个网站上例句的hadoop 和storm的知识体系.所以列出来供大家了解和学习.来自哪个网站就不写了以免以为我做广告额. 目录结构知识点还是挺全 ...
- CSI-MIPI学习笔记
一.mipi LCD 的CLK时钟频率与显示分辨率及帧率的关系 公式: Mipiclock = [ (width+hsync+hfp+hbp) x (height+vsync+vfp+vbp) ] x ...
- 转 Apache Kafka:下一代分布式消息系统
简介 Apache Kafka是分布式发布-订阅消息系统.它最初由LinkedIn公司开发,之后成为Apache项目的一部分.Kafka是一种快速.可扩展的.设计内在就是分布式的,分区的和可复制的提交 ...
- 利用Xamaria构建Android应用-公交发车信息屏
原文:利用Xamaria构建Android应用-公交发车信息屏 1.背景 在公交整个运营系统中,信息展示占据了很大一部分的内容.各种除了户外的各种LED拼接屏,还有用于室内信息提示用的LCD屏幕.对于 ...
- FastAdmin 将会员模块升级为基础模块的升级指导
说明 FastAdmin 于 2018-01-19 将会员模块升级为基础模块. 因为有数据库改动,所以需要对旧的数据库进行升级,不然没有办法使用和显示. 升级流程 git 合并代码 略 导入数据表 D ...
- zstack快速安装文档
1.环境准备 1.1 准备软件工具 系统镜像 ZStack-x86_64-DVD-2.1.1.514.iso Zstack安装包 ZStack-installer-2.1.1.514.bin http ...