zoukankan      html  css  js  c++  java
  • 11g 关于自动搜集统计信息

    在11g之前,当表的数据量修改超过总数据量的10%,就会晚上自动收集统计信息,如何判断10%,之前的帖子有研究过:Oracle自动统计信息的收集原理及实验。这个STALE_PERCENT=10%,是无法修改的,如果表非常大,10%是非常多的数据,非常有可能造成统计信息不准确。
    
        在11g之后,STALE_PERCENT=10%是可以修改的,分为全局(DBMS_STATS.SET_GLOBAL_PREFS )和表级别(DBMS_STATS.SET_TABLE_PREFS)。表级别的设定:
    
        修改为5%(范围从1-100): exec dbms_stats.set_table_prefs(null,'table_name','STALE_PERCENT',5);
        恢复为10%: exec dbms_stats.set_table_prefs(null,'table_name','STALE_PERCENT',null);
        查询百分比:select dbms_stats.get_prefs('STALE_PERCENT',null,'table_name') from dual; 
    
    ---11g的是 周一到周五 22:00-2:00 周六周日 6:00-4:00
    
    
    SQL> col REPEAT_INTERVAL format a50
    SQL> SELECT w.window_name, w.repeat_interval, w.duration, w.enabled
    FROM dba_autotask_window_clients c, dba_scheduler_windows w
    WHERE c.window_name = w.window_name
    AND c.optimizer_stats = 'ENABLED';  2    3    4  
    
    WINDOW_NAME	     REPEAT_INTERVAL					DURATION   ENABL
    -------------------- -------------------------------------------------- ---------- -----
    MONDAY_WINDOW	     freq=daily;byday=MON;byhour=22;byminute=0; bysecon +000 04:00 TRUE
    		     d=0						:00
    
    TUESDAY_WINDOW	     freq=daily;byday=TUE;byhour=22;byminute=0; bysecon +000 04:00 TRUE
    		     d=0						:00
    
    WEDNESDAY_WINDOW     freq=daily;byday=WED;byhour=22;byminute=0; bysecon +000 04:00 TRUE
    		     d=0						:00
    
    THURSDAY_WINDOW      freq=daily;byday=THU;byhour=22;byminute=0; bysecon +000 04:00 TRUE
    		     d=0						:00
    
    FRIDAY_WINDOW	     freq=daily;byday=FRI;byhour=22;byminute=0; bysecon +000 04:00 TRUE
    		     d=0						:00
    
    SATURDAY_WINDOW      freq=daily;byday=SAT;byhour=6;byminute=0; bysecond +000 20:00 TRUE
    		     =0 						:00
    
    SUNDAY_WINDOW	     freq=daily;byday=SUN;byhour=6;byminute=0; bysecond +000 20:00 TRUE
    		     =0 						:00
    
    
    7 rows selected.
    周一到周五 是22点开始 持续4个小时
    
    周六到周日 是6点开始 持续20个小时
    
    --禁用自动收集
    exec DBMS_AUTO_TASK_ADMIN.DISABLE(client_name => 'auto optimizer stats collection',operation => NULL,window_name => NULL);
    --启用自动收集
    exec DBMS_AUTO_TASK_ADMIN.ENABLE(client_name => 'auto optimizer stats collection',operation => NULL,window_name => NULL);
    --查看job
    
    select client_name,status from dba_autotask_client;
    
    CLIENT_NAME                                                      STATUS
    ---------------------------------------------------------------- --------
    auto optimizer stats collection                                  ENABLED
    auto space advisor                                              ENABLED
    sql tuning advisor                                              ENABLED
    
    
    --收集当前数据库下所有用户的统计信息
    exec dbms_stats.gather_database_stats(user);
    --收集当前数据库用户下所有对象的统计信息
    exec dbms_stats.gather_schema_stats(user);
    --收集数据字典的统计信息
    exec dbms_stats.gather_dictionary_stats(); 
    --当系统有很大的分区表时,如果总是全部收集则会比较慢,11g之后可以设置INCREMENTAL只对数据有变动的分区做收集
    
    exec dbms_stats.set_table_prefs(user,'table_name','INCREMENTAL','TRUE');--只收集数据变动的分区
    
    exec dbms_stats.set_table_prefs(user,'table_name','INCREMENTAL','FALSE');--都要收集
    
    select dbms_stats.get_prefs('INCREMENTAL',null,'table_name') from dual;--查看分区表INCREMENTAL的值
    
    
    --获取global的统计信息收集设置选项
    select dbms_stats.get_prefs('method_opt') from dual;
    select dbms_stats.get_prefs('concurrent') from dual; 
    select dbms_stats.get_prefs('GRANULARITY') from dual;
    
    select dbms_stats.get_prefs('INCREMENTAL') from dual;
    --设置global的统计信息收集选项
    
    
    exec DBMS_STATS.SET_PARAM('DEGREE',4);
    
    exec DBMS_STATS.SET_PARAM('INCREMENTAL','TRUE');

  • 相关阅读:
    markdown转HTML,目录生成
    schedule与scheduleAtFixedRate之Timer源码分析
    rocketmq刷盘过程
    rocketmq消息存储概述
    Cassandra修改集群名称
    Cassandra读写性能测试
    rocketmq--push消费过程
    rocketmq消费负载均衡--push消费为例
    go反射实例
    JUnit4参数的使用
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13351824.html
Copyright © 2011-2022 走看看