今天做SQL執行計劃測試的時候,發現sqlplus無法正常打印執行計劃,根據網上資料整理如下:
.....
SYS@orcl> select *
2 from table(
3 dbms_xplan.display_cursor( format=> 'allstats last' )
4 )
5 /
PLAN_TABLE_OUTPUT
------------------------------------------------------------------------------
SQL_ID 9babjv8yq8ru3, child number 0
BEGIN DBMS_OUTPUT.GET_LINES(:LINES, :NUMLINES); END;
NOTE: cannot fetch plan for SQL_ID: 9babjv8yq8ru3, CHILD_NUMBER: 0
Please verify value of SQL_ID and CHILD_NUMBER;
It could also be that the plan is no longer in cursor cache (check v$sql
_plan)
注意: 標紅的SQL_ID確實不存在,原因是SQLPLUS打開了SERVEROUTPUT ,TOM的解釋如下:
do you see the sql it is showing - dbms_output.get_lines....
the last sql your session executed was in fact that call - sqlplus does that when you have set serveroutput on
issue 解決方法:
set serveroutput off
and try it... 再次查詢
-------------------------------
Dylan Presents.