前段时间在跑生产数据时,一句简单的sql语句跑了很长时间都没有跑出来,想了多种办法,还是不行, 后来同事通过执行计划,发现执行计划中每个表的cost都非常小,且都使用了索引,然后确定是统计信息过期导致的错误的执行计划。
1.找到从未收集过统计信息或者统计信息过期的表。
EXEC DBMS_STATS.FLUSH_DATABASE_MONITORING_INFO;SELECT OWNER,TABLE_NAME,OBJECT_TYPE,STALE_STATS,LAST_ANALYZED FROM
DBA_TAB_STATISTICS WHERE (STALE_STATS='YES' OR LAST_ANALYZED IS NULL)
AND OWNER NOT IN ('SYS', 'SYSTEM', 'SYSMAN', 'DMSYS', 'OLAPSYS', 'XDB','EXFSYS', 'CTXSYS',
'WMSYS', 'DBSNMP', 'ORDSYS', 'OUTLN', 'TSMSYS', 'MDSYS') AND TABLE_NAME NOT LIKE 'BIN%';
2.在进行调优之前,要看表的统计信息是否过期,如果过期了,CBO就可能选择错误的执行计划。
SELECT OWNER,TABLE_NAME,OBJECT_TYPE,STALE_STATS,LAST_ANALYZED FROM DBA_TAB_STATISTICS WHERE OWNER='&OWNER' AND TABLE_NAME='&TABLE_NAME';