PLSQL_统计信息系列06_统计信息的历史和日志

20150506 Created By BaoXinjian

 一、摘要


通过使用dbms_stats包来收集系统和对象的统计信息,在写新的统计信息时,系统会将当前的统计信息备份到数据字典中,从而保留一段时间的统计信息,如果新的统计信息导致低效的执行计划,可以恢复到旧的合适的统计信息

1. 保留时间和清除

2. 视图

3. 恢复统计信息

4. 日志

 

 二、解析


1. 保留时间和清除

(1). 查看保留时间

select dbms_stats.get_stats_history_retention() as retention

from dual;

(2). 设定保留时间

dbms_stats.alter_stats_history_retention(retention => 31); 

(3). 清楚统计信息

dbms_stats.purge_stats(before_timestamp => systimestamp-31);

2. 视图

查看某个对象的统计信息的变化情况,通过表dba_tab_stats_history获取对象的统计信息何时被修改

select stats_update_time

  from dba_tab_stats_history

 where owner = 'SYS'

   and table_name = 'WRH$_SYSSTAT'

3. 恢复统计信息

dbms_stats.restore_schema_stats(ownname => 'SH',

                                as_of_imestamp => systimestamp-1,

                                force => TRUE)

4.  日志

将数据库、数据字典、模式级别的操作执行信息记录到数据字典中,可通过查看如下表获取这些日志信息

select operation,

       start_time,

       (end_time - start_time) day(1) to second(0) as duration

  from dba_optstat_operations

 order by start_time desc;

 

Thanks and Regards

你可能感兴趣的:(plsql)