当前位置: 首页 > article >正文

关于DBMS_STATS.GATHER_DATABASE_STATS_JOB_PROC的一些发现

任务在哪

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

SQL> SELECT CLIENT_NAME               ,
       STATUS                    ,
       MEAN_INCOMING_TASKS_7_DAYS,
       MEAN_INCOMING_TASKS_30_DAYS
FROM   DBA_AUTOTASK_CLIENT
WHERE  CLIENT_NAME = 'auto optimizer stats collection'
/  2    3    4    5    6    7  

CLIENT_NAME                                                      STATUS
---------------------------------------------------------------- --------
MEAN_INCOMING_TASKS_7_DAYS MEAN_INCOMING_TASKS_30_DAYS
-------------------------- ---------------------------
auto optimizer stats collection                                  ENABLED
                         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的列表

SQL> 
set line 150
set serveroutput on
declare
  obj_auto dbms_stats.ObjectTab;
begin
  dbms_stats.gather_database_stats(options => 'LIST AUTO',objlist => obj_auto);
  for i in 1..obj_auto.count
    loop
      dbms_output.put_line('Auto list---> Owner:  '||obj_auto(i).ownname||'   Object name:  '||obj_auto(i).objName||'- -Object type:  '||obj_auto(i).objType);
      end loop;  
end;
/


http://www.kler.cn/a/134060.html

相关文章:

  • 随时随地编码:香橙派Zero3上安装Code Server远程开发指南
  • 【go从零单排】JSON序列化和反序列化
  • java八股-jvm入门-程序计数器,堆,元空间,虚拟机栈,本地方法栈,类加载器,双亲委派,类加载执行过程
  • OpenGL ES 共享上下文实现多线程渲染
  • Vue 3 介绍及应用
  • HarmonyOS Next星河版笔记--界面开发(4)
  • 自学嵌入式,已经会用stm32做各种小东西了
  • 小米路由器AX1800降级后的SSH登录和关墙等命令
  • 【数据结构(二)】队列(2)
  • centos7安装mongodb
  • Cross-View Transformers for Real-Time Map-View Semantic Segmentation 论文阅读
  • 木子-前端-方法标签属性小记(普通jsp/html篇)2023~2024
  • Redis为什么是单线程的?Redis性能为什么很快?
  • psql 模式(SCHEMA)
  • ICCV 23丨3D-VisTA:用于 3D 视觉和文本对齐的预训练Transformer
  • python科研绘图:面积图
  • 一些RLHF的平替汇总
  • c语言常见的面试问题
  • Qt HTTP 摘要认证(海康球机摄像机ISAPI开发)
  • C语言——1.入门须知
  • TikTok与媒体素养:如何辨别虚假信息?
  • SpirngBoot + Vue 前后端分离开发工具代码
  • 阶乘算法优化
  • curl网络请求命令
  • milvus数据库索引管理
  • ClickHouse查看执行计划