• 关于DBMS_STATS.GATHER_DATABASE_STATS_JOB_PROC的一些发现


    任务在哪

    这个是11g以后的自动收集统计信息的后台任务,10g之前是在dba_scheduler_jobs里查看

    1. SQL> SELECT CLIENT_NAME ,
    2. STATUS ,
    3. MEAN_INCOMING_TASKS_7_DAYS,
    4. MEAN_INCOMING_TASKS_30_DAYS
    5. FROM DBA_AUTOTASK_CLIENT
    6. WHERE CLIENT_NAME = 'auto optimizer stats collection'
    7. / 2 3 4 5 6 7
    8. CLIENT_NAME STATUS
    9. ---------------------------------------------------------------- --------
    10. MEAN_INCOMING_TASKS_7_DAYS MEAN_INCOMING_TASKS_30_DAYS
    11. -------------------------- ---------------------------
    12. auto optimizer stats collection ENABLED
    13. 2 2.25806452

    可以在dba_autotask_job_history中看到历史执行情况

    什么原理

    根据1592404.1,后台的GATHER_DATABASE_STATS_JOB_PROC就是使用gather auto的option的情况。

    根据1233203.1

    How does auto optimizer stats collection prioritize which tables are analyzed first?

    Accurate statistics are important on all objects. The GATHER_DATABASE_STATS_JOB_PROC procedure called by the 'auto optimizer stats collection' job prioritizes database objects that have no statistics. This means that objects that most need statistics are processed first. Once these are done then objects with stale statistics are addressed. For these, there is no particular prioritization. The statistics may be ordered in some way but it is cursory, ordering by owner,object_name,part_name just to be consistent. 

    基本是先收集empty的,再收集stale的,剩下的按用户,对象名,分区名等。

    观测手段

    可以用以下过程查看下一次gather auto的列表

    1. SQL>
    2. set line 150
    3. set serveroutput on
    4. declare
    5. obj_auto dbms_stats.ObjectTab;
    6. begin
    7. dbms_stats.gather_database_stats(options => 'LIST AUTO',objlist => obj_auto);
    8. for i in 1..obj_auto.count
    9. loop
    10. dbms_output.put_line('Auto list---> Owner: '||obj_auto(i).ownname||' Object name: '||obj_auto(i).objName||'- -Object type: '||obj_auto(i).objType);
    11. end loop;
    12. end;
    13. /

  • 相关阅读:
    CVE-2021-22205 Github upload RCE漏洞复现
    萌新卷妹带你逃出算法无名岛第四站
    [数据结构]~堆
    路由的控制与转发原理
    你真的了解 RSA 加密算法吗?
    第六部分--模板
    python画板
    快来了解一下5个超实用的WPS表格操作技巧!
    GitHub每日最火火火项目(9.16)
    T、Class<T>以及Class<?>的理解
  • 原文地址:https://blog.csdn.net/q195136130/article/details/134497473