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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值