♣题目 部分
在Oracle中,如何获取SQL历史执行计划?
♣答案部分
历史执行计划只能从AWR中获取,如果AWR没有记录的话,那么就无法获取历史执行计划了,获取历史执行计划的命令如下所示:
1SELECT * FROM TABLE(DBMS_XPLAN.DISPLAY_AWR('&sqlid'));
对于历史计划,可以生成SQL报告,命令如下所示:
1SELECT * FROM TABLE(DBMS_WORKLOAD_REPOSITORY.AWR_SQL_REPORT_HTML(L_DBID => , L_INST_NUM => , L_BID => , L_EID => , L_SQLID => )) ;
其中,L_DBID代表数据库的DBID,L_INST_NUM代表数据库的实例号,单机环境为1,RAC环境填写具体的实例号,L_BID为开始的快照号,L_EID为结束的快照号,L_SQLID为要查看SQL的SQL_ID。
下面的例子可以直接从AWR中获取SQL_ID为“bsa0wjtftg3uw”的执行计划,可以看到历史有2种执行计划,一个是全表扫描,一个是索引范围扫描:
1SYS@RAC2LHR1> SELECT * FROM TABLE(DBMS_XPLAN.DISPLAY_AWR(SQL_ID => 'bsa0wjtftg3uw' )) ;
2SQL_ID bsa0wjtftg3uw
3--------------------
4SELECT file# FROM file$ WHERE ts#=:1
5Plan hash value: 690176192
6-----------------------------------------------
7| Id | Operation | Name |
8-----------------------------------------------
9| 0 | SELECT STATEMENT | |
10| 1 | TABLE ACCESS BY INDEX ROWID| FILE$ |
11| 2 | INDEX RANGE SCAN | I_FILE2 |
12-----------------------------------------------
13Note
14-----
15 - rule based optimizer used (consider using cbo)
16SQL_ID bsa0wjtftg3uw
17--------------------
18SELECT file# FROM file$ WHERE ts#=:1
19Plan hash value: 3494626068
20---------------------------------------------------------------------------
21| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
22---------------------------------------------------------------------------
23| 0 | SELECT STATEMENT | | | | 2 (100)| |
24| 1 | TABLE ACCESS FULL| FILE$ | 1 | 6 | 2 (0)| 00:00:01 |
25---------------------------------------------------------------------------
2631 rows selected.
作者:李华荣。