如何 找出未收集统计信息,以及统计信息过期的表
2010-03-29 15:28
375 查看
下面这个查询可以找到从未收集过统计信息或者统计信息过期的表。
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%';
在进行调优之前,我们就要看表的统计信息是否过期,如果过期了,CBO就可能选择错误的执行计划。
SELECT OWNER,TABLE_NAME,OBJECT_TYPE,STALE_STATS,LAST_ANALYZED FROM DBA_TAB_STATISTICS WHERE OWNER='&OWNER' AND TABLE_NAME='&TABLE_NAME';
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%';
在进行调优之前,我们就要看表的统计信息是否过期,如果过期了,CBO就可能选择错误的执行计划。
SELECT OWNER,TABLE_NAME,OBJECT_TYPE,STALE_STATS,LAST_ANALYZED FROM DBA_TAB_STATISTICS WHERE OWNER='&OWNER' AND TABLE_NAME='&TABLE_NAME';
相关文章推荐
- 如何 找出未收集统计信息,以及统计信息过期的表
- 如何 找出未收集统计信息,以及统计信息过期的表
- 找出未收集统计信息,以及统计信息过期的表
- 什么是统计信息以及收集查看方法
- oracle 10g如何关闭和打开自动收集统计信息
- oracle 10g如何关闭和打开自动收集统计信息
- Oracle 统计信息过期的表重新收集统计信息
- oracle 10g如何关闭和打开自动收集统计信息
- 11g新特性-如何禁用自动统计信息收集作业
- 如何关闭和打开oracle 10g自动收集统计信息功能
- 11g中如何禁用自动统计信息收集作业
- db2 中索引统计信息(防止失效) 以及如何定时执行
- 如何收集及删除列的统计信息
- oracle 10g如何关闭和打开自动收集统计信息
- 11g中如何禁用自动统计信息收集作业
- 11g中如何禁用自动统计信息收集作业?
- 如何检测过期的统计信息(转)
- oracle 10g如何关闭和打开自动收集统计信息
- 什么是统计信息以及收集查看方法
- 从一个SQL使用了不理想的执行计划说开,浅谈执行计划如何估算cache信息的影响及系统统计信息的收集等(2010-10-15)