更新Oracle表的统计信息 GATHER_TABLE_STATS

2014-11-24 18:21:23 · 作者: · 浏览: 0

需要用到dbms_stats这个包的GATHER_TABLE_STATS过程,其中拥有者和表名必须填。


PROCEDURE GATHER_TABLE_STATS
Argument Name Type In/Out Default
------------------------------ ----------------------- ------ --------
OWNNAME VARCHAR2 IN
TABNAME VARCHAR2 IN
PARTNAME VARCHAR2 IN DEFAULT
ESTIMATE_PERCENT NUMBER IN DEFAULT
BLOCK_SAMPLE BOOLEAN IN DEFAULT
METHOD_OPT VARCHAR2 IN DEFAULT
DEGREE NUMBER IN DEFAULT
GRANULARITY VARCHAR2 IN DEFAULT
CASCADE BOOLEAN IN DEFAULT
STATTAB VARCHAR2 IN DEFAULT
STATID VARCHAR2 IN DEFAULT
STATOWN VARCHAR2 IN DEFAULT
NO_INVALIDATE BOOLEAN IN DEFAULT
STATTYPE VARCHAR2 IN DEFAULT
FORCE BOOLEAN IN DEFAULT


exec dbms_stats.gather_table_stats('SCOTT','D');



表的统计信息不是实时取的。所以有时候刚刚delete掉表中数据,并不能实时从user_tables中的num_rows反应出来。这时候收集下表的统计信息即可。



SQL> select table_name ,num_rows from user_tables where table_name='D';


TABLE_NAME NUM_ROWS
--------------- ----------
D 4


SQL> select * from d;


DEPTNO DNAME
---------- ----------------------------
10 ACCOUNTING
20 RESEARCH
30 SALES
40 OPERATIONS


SQL> delete from d where deptno=30;


1 row deleted.


SQL> commit;


Commit complete.


SQL> select * from d;


DEPTNO DNAME
---------- ----------------------------
10 ACCOUNTING
20 RESEARCH
40 OPERATIONS


SQL> select table_name ,num_rows from user_tables where table_name='D';


TABLE_NAME NUM_ROWS
--------------- ----------
D 4


这时候行数还是4。我们收集下统计信息。


SQL> exec dbms_stats.gather_table_stats('SCOTT','D');


PL/SQL procedure successfully completed.


SQL> select table_name ,num_rows from user_tables where table_name='D';


TABLE_NAME NUM_ROWS
--------------- ----------
D 3



==============================================================================================


还原刚才删掉的数据……



SQL> alter session set nls_date_format ='yyyy-mm-dd hh24:mi:ss';



Session altered.


SQL> SQL>
SQL> select sysdate from dual;


SYSDATE
-------------------
2012-02-28 05:01:49


SQL> select * from d as of timestamp to_timestamp('2012-02-28 04:50:00','yyyy-mm-dd hh24:mi:ss') where deptno=30;


DEPTNO DNAME
---------- ----------------------------
30 SALES


SQL> insert into d select * from d as of timestamp to_timestamp('2012-02-28 04:50:00','yyyy-mm-dd hh24:mi:ss') where deptno=30;


1 row created.


SQL> select * from d;


DEPTNO DNAME
---------- ----------------------------
10 ACCOUNTING
20 RESEARCH
40 OPERATIONS
30 SALES


SQL> commit;


Commit complete.