简单判断表统计信息是否准确
=============
在cbo模式下,统计信息是sql解析后优化以及选择执行计划的依据
如果统计信息部准确会导致sql解析后不能选择最正确的执行计划
一般统计信息都记录在系统表中
通过dbms_stats包或者analyze命令可以重新获得统计信息
如何获得统计信息不是本文重点
可以按照一下方式简单的确认一个表是否有准确的统计信息
方式:查询user_tables,查询字段:num_rows
解释:统计信息部准确时该字段中没有值
以下是实验环境
SQL> select * from v$version;
BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production
PL/SQL Release 11.2.0.1.0 - Production
CORE 11.2.0.1.0 Production
TNS for 32-bit Windows: Version 11.2.0.1.0 - Production
NLSRTL Version 11.2.0.1.0 - Production
查询user_tables表,num_rows字段为空
SQL> select table_name,num_rows from user_tables where rownum<11;
TABLE_NAME NUM_ROWS
------------------------------ ----------
AN
TEST
AN1
AN2
分析表an后查询,num_rows中为表中准确数据量
SQL> analyze table an compute statistics;
表已分析。
SQL> select table_name,num_rows from user_tables where rownum<11;
TABLE_NAME NUM_ROWS
------------------------------ ----------
AN 2
TEST
AN1
AN2
分析全部表,最终查到所有表的数据量统计
SQL> analyze table &table_name compute statistics;
输入 table_name 的值: test
原值 1: analyze table &table_name compute statistics
新值 1: analyze table test compute statistics
表已分析。
SQL> /
输入 table_name 的值: an1
原值 1: analyze table &table_name compute statistics
新值 1: analyze table an1 compute statistics
表已分析。
SQL> /
输入 table_name 的值: an2
原值 1: analyze table &table_name compute statistics
新值 1: analyze table an2 compute statistics
表已分析。
SQL> select table_name,num_rows from user_tables where rownum<11;
TABLE_NAME NUM_ROWS
------------------------------ ----------
AN 2
TEST 1
AN1 0
AN2 0