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
ERP技术讨论群: 288307890
技术交流,技术讨论,欢迎加入
Technology Blog Created By Oracle ERP - 鲍新建