cannot fetch plan for SQL_ID_MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 1782 | 回复: 0   主题: cannot fetch plan for SQL_ID        下一篇 
wzj
注册用户
等级:新兵
经验:67
发帖:64
精华:0
注册:2011-11-15
状态:离线
发送短消息息给wzj 加好友    发送短消息息给wzj 发消息
发表于: IP:您无权察看 2015-7-8 14:59:22 | [全部帖] [楼主帖] 楼主

    1、故障现象  

    -->使用display_cursor提取执行计划失败

    admin@CADB> select * fromtable(dbms_xplan.display_cursor(null,null,'iostats last'));

    PLAN_TABLE_OUTPUT

    ---------------------------------------------------------------------------------------------------

    SQL_ID  9babjv8yq8ru3, child number 3

    BEGIN DBMS_OUTPUT.GET_LINES(:LINES, :NUMLINES); END;

    NOTE: cannot fetch plan for SQL_ID: 9babjv8yq8ru3, CHILD_NUMBER: 3

    Please verify value of SQL_ID and CHILD_NUMBER;

    It could also be that the plan isno longer incursor cache (check v$sql_plan)

    -->查看serveroutput设置值,此时为ON,再次调用dbms_xplan.display_cursor,此时故障同上

    scott@CADB> show serveroutput

    serveroutput ONSIZE 1000000 FORMAT WORD_WRAPPED

    scott@CADB> select /*+ gather_plan_statistics */ * from dept;

    DEPTNO DNAME          LOC

    ---------- -------------- -------------

    10 ACCOUNTING     NEW YORK

    20 RESEARCH       DALLAS

    30 SALES          CHICAGO

    40 OPERATIONS     BOSTON

    50 DEVELOPE       CHINA

    scott@CADB> select * fromtable(dbms_xplan.display_cursor(null,null,'iostats last'));

    PLAN_TABLE_OUTPUT

    ----------------------------------------------------------------------------------------------

    SQL_ID  9babjv8yq8ru3, child number 2

    BEGIN DBMS_OUTPUT.GET_LINES(:LINES, :NUMLINES); END;

    NOTE: cannot fetch plan for SQL_ID: 9babjv8yq8ru3, CHILD_NUMBER: 2

    Please verify value of SQL_ID and CHILD_NUMBER;

    It could also be that the plan isno longer incursor cache (check v$sql_plan)

    2、解决故障  

    -->关闭serveroutput选项

    scott@CADB> set serveroutput off;

    scott@CADB> select /*+ gather_plan_statistics */ * from dept;

    DEPTNO DNAME          LOC

    ---------- -------------- -------------

    10 ACCOUNTING     NEW YORK

    20 RESEARCH       DALLAS

    30 SALES          CHICAGO

    40 OPERATIONS     BOSTON

    50 DEVELOPE       CHINA

    -->此时成功提取执行计划

    scott@CADB> select * fromtable(dbms_xplan.display_cursor(null,null,'iostats last'));

    PLAN_TABLE_OUTPUT

    ------------------------------------------------------------------------------------------------

    SQL_ID  08u3pfapxj6g5, child number 0

    -------------------------------------

    select /*+ gather_plan_statistics */ * from dept

    Plan hash value: 3383998547

    ------------------------------------------------------------------------------------

    Id    Operation           Name   Starts   E-Rows   A-Rows     A-Time     Buffers

    ------------------------------------------------------------------------------------

    1    TABLE ACCESS FULL  DEPT        1        5        5  00:00:00.01         8

    ------------------------------------------------------------------------------------

    12 rows selected.

    -->下面使用explain plan加载执行计划到plan_table,然后使用dbms_xplan.display提取执行计划

    -->从下面的实现中可知,serveroutput不影响从plan_table提取执行计划

    scott@CADB> show serveroutput

    serveroutput ONSIZE 1000000 FORMAT WORD_WRAPPED

    scott@CADB> explain plan forselectcount(*) from emp;

    Explained.

    scott@CADB> select * fromtable(dbms_xplan.display);

    PLAN_TABLE_OUTPUT

    -----------------------------------------------------------------------------------------------------------------------------------

    Plan hash value: 1858788047

    -------------------------------------------------------------------------

    Id    Operation          Name           Rows    Cost (%CPU)  Time

    -------------------------------------------------------------------------

    0   SELECT STATEMENT                      1       1   (0)  00:00:01

    1    SORT AGGREGATE                       1

    2     INDEXFULL SCAN  I_EMP_DEPTNO      14       1   (0)  00:00:01

    -------------------------------------------------------------------------

    9 rows selected.

    -->很多时候DBA在login.sql 或 glogin.sql 时指定了serveroutput为ON,以便在执行PL/SQL时能正常输出,而在获取SQL的执行计划时,恰恰

    -->由于该设置而导致无法提取执行计划。不过serveroutput不影响从plan_table提取执行计划。

    --转自 北京联动北方科技有限公司




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论