dbms_xplan之display_cursor函數的使用

文章來源: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,如需轉載請自行聯系原作者


本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/257030.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/257030.shtml
英文地址,請注明出處:http://en.pswp.cn/news/257030.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

H5+JS實現《Just Do 8》游戲源碼分享

【界面效果圖】 【代碼結構】 【代碼結構解釋】 1、使用html語言實現數據 2、使用css3語言實現樣式 3、使用JS語言實現路基控制 【注意是想】 1、如需查看效果&#xff0c;請使用手機瀏覽器&#xff0c;或者使用appcan打包查看 2、如果使用瀏覽器&#xff0c;請選擇google的Chr…

windows下的結束標志

空格 ctrlz ctrlz 回車 int main() { stack<string> ss; //std::vector<int> ss; string str; cout<<"請輸入字符串"<<endl; while(cin>>str) { ss.push(str); //if(str[0]1) …

前端架構知識體系

0. 前端自動化(Workflow) 前端構建工具 Yeoman – a set of tools for automating development workflowgulp – The streaming build systemgrunt – the JavaScript Task RunnerF.I.S – 前端集成解決方案webpackNPM前端模塊管理器 Bower – A package manager for the webBr…

python數據結構_大O符號_學習筆記(1)

1.概念 &#xff1a;大O符號是用來表達一個算法的復雜程度的&#xff0c;是一個數量級 2.代碼 a 1 b 2 c 3 for i in range(n):for j in range(n):x i*iy j*jz i*jfor k in range(n):m a*k 5v k*kd 100*c e c*d3.分析 在上述代碼中&#xff0c;分配操作數分為四…

.NET簡談組件程序設計之(上下文與同步域)

我們繼續學習.NET多線程技術&#xff0c;這篇文章的內容可能有點復雜。在打破常理之后&#xff0c;換一種新的思考模型最為頭疼。這篇文章里面會涉及到一些不太常見的概念&#xff0c;比如&#xff1a;上下文、同步域等等。我也是最近才接觸這些關于組件編程方面的高深技術&…

string類的各種函數用法

標準c中string類函數介紹 注意不是CString 之所以拋棄char*的字符串而選用C標準程序庫中的string類&#xff0c;是因為他和前者比較起來&#xff0c;不必 擔心內存是否足夠、字符串長度等等&#xff0c;而且作為一個類出現&#xff0c;他集成的操作函數足以完成我們大多數情況…

調用圖片按鈕的img圖片

今天是我學前端的第12天。早上起床后活動筋骨時看了《JS的基本屬性操作》&#xff0c;作業是模擬手機發送短信。文字都能傳輸到<div>上&#xff0c;就是圖片不知道怎么傳。折騰了好久才弄清楚&#xff0c;多虧了某群的小伙伴們。 這一節課&#xff0c;我學會了如何調用圖…

利用api接口來實現web網頁登陸

因為公司的所有鏈接數據庫的都是用的api接口 最近做了一個用api接口登陸 function Login() { if (!Validate()) { return false; } var para {}; para.action "login_by_api"; para.login_name $.trim($("#txtLoginName").val()); para.password $.tr…

Cisco設備做流量監控的方法

方法一&#xff1a;HUB&#xff08;方法太簡單。。。略&#xff09;方法二&#xff1a;TAP&#xff08;太專業了。。還要另外投資&#xff09;方法三&#xff1a;SPAN&#xff08;就是大家常說得Port Mirror或者Port Monitor&#xff09;1。Cat2900XL/3500XL2900XL(config)#int…

python數據結構_(列表)大O性能_學習筆記(2)

1.列表 1&#xff09;一般列表操作命令的復雜度&#xff08;準確來說是函數的復雜度&#xff09; 2&#xff09;時間計算&#xff08;timeit模塊和Timer對象&#xff09; 要捕獲我們的每個函數執行所需的時間&#xff0c;我們將使用 Python 的 timeit 模塊。timeit 模塊旨在 …

學習C++不要糾結了

阿里&#xff0c;騰訊2家公司均工作過。處理高并發的底層基本都是使用C來完成的&#xff0c;騰訊確實90%的程序員都是C程序員&#xff0c;而且基本每個C程序員都有2本磚頭書---unix 環境高級編程 和 C Primer。 阿里大部分程序員都是JAVA程序員&#xff0c;但在關鍵的節點還是會…

找到你的位置(JS在頁面中的位置)最常用的方式是在頁面中head部分放置script元素,瀏覽器解析head部分就會執行這個代碼,然后才解析頁面的其余部分...

找到你的位置&#xff08;JS在頁面中的位置&#xff09; 我們可以將JavaScript代碼放在html文件中任何位置&#xff0c;但是我們一般放在網頁的head或者body部分。放在<head>部分 最常用的方式是在頁面中head部分放置<script>元素&#xff0c;瀏覽器解析head部分就…

國內主流.NET CMS系統整理

現在只要想做一個網站&#xff0c;馬上就想到去下載一個cms來改&#xff0c;方便&#xff0c;快速&#xff0c;現如今在網上隨便搜索下CMS都出現幾十個不一樣的品牌&#xff0c;有php的、java的、.net的&#xff0c;功能上也是各有千秋&#xff0c;如何選擇一個比較適合自己的C…

數據庫的事務級別介紹與操作

關系型數據庫都具有一套事務級別&#xff0c;以前的開發和學習過程我很少關注過這個概念&#xff0c;今天搜集了一些資料&#xff0c;在 結合spring聲明式事務學習的同時&#xff0c;總結一下數據庫的事務級別與操作。 READ-UNCOMMITTED: 未提交讀 會出現臟讀、不可重復讀、幻讀…

中國做圖像處理的公司

&#xff08;1&#xff09; 北京北方獵波科技有限公司&#xff1a;http://www.northwh.com/beifangliebo/main1.html 紅外探測成像產品 &#xff08;2&#xff09; 深圳超多維光電子有限公司北京分公司&#xff1a;http://www.superd.com.cn 立體顯示設備 &#xff08;3&…

[ilink32 Error] Error: Unresolved external 'SendARP'

[ilink32 Error] Error: Unresolved external SendARP referenced from E:\APPOBJ\KSRGETMAC.OBJ #pragma link "iphlpapi.lib" 轉載于:https://www.cnblogs.com/cb168/p/5573478.html

3.cocos2dx它Menu,由menu為了實現場景切換

&#xfeff;&#xfeff;1 頭文件 TMenu.h #ifndef __TMENU_H__ #define __TMENU_H__ #include "cocos2d.h" USING_NS_CC; class TMenu :public CCLayer { public: static CCScene * scene(); CREATE_FUNC(TMenu); bool init(); CCMenu * menu; void menuCallback(C…

Difference: throw or throw ex?

Difference: throw or throw ex? 主要區別在于throw出的堆棧詳細程度。 throw ex只是拋出在當前代碼處的錯誤。 throw 能夠更進一步&#xff0c;拋出內部調用的具體錯誤。 Just for demonstrating, if you have classes in C# as follows: using System;namespace WindowsAppl…

學習筆記01:1.1 基于概率的信任

基于概率的信任 大數定律&#xff1a;當樣本數量越來越多時&#xff0c;預測事件也就越來越接近于真實的事件&#xff0c;事件出現的頻率無窮地接近事件發生的概率建模檢驗&#xff1a;人工規則->學習模型&#xff0c;數據少則重視先驗&#xff0c;數據多則重視后驗給予概率…