查看语句的历史执行信息,是否发生变化,何时发生了变化。如果发生了变化,找出以前的执行计划,与当前的执行计划进行对比,有什么不同。 使用如下sql 可以发现某个sql的执行计划什么时候发生了变化! select distinct SQL_ID, PLAN_HASH_VALUE, to_char(TIMESTAMP, 'yyyymmdd hh34:mi:ss') TIMESTAMP from dba_hist_sql_plan where SQL_ID = '68wnxdjxwwn2h' order by TIMESTAMP;
查看出来执行计划的变化之后 可以使用如下sql查看发生了那些变化! col options for a15 col operation for a20 col object_name for a20 select plan_hash_value, id, operation, options, object_name, depth, cost, to_char(TIMESTAMP, 'yyyymmdd hh34:mi:ss') from DBA_HIST_SQL_PLAN where sql_id = '68wnxdjxwwn2h' and plan_hash_value in (1542630049, 2754593971, 2620382595) order by TIMESTAMP,ID;