写点什么

【YashanDB 知识库】如何更改自动统计信息收集任务

作者:YashanDB
  • 2025-01-20
    广东
  • 本文字数:625 字

    阅读完需:约 2 分钟

本文内容来自 YashanDB 官网,原文内容请见https://www.yashandb.com/newsinfo/7106887.html?templateId=1718516


YashanDB 内置了定时任务 GATHER_STATS_JOB,默认每日凌晨 2:00 开始收集全库的统计信息,包括统计信息缺失或者统计信息已经失效的对象的收集。

 

在某些场景可能出现收集过程花费时间较长现象,可通过调整收集参数,加快收集过程。

1、删除系统默认收集任务

EXEC DBMS_SCHEDULER.DROP_JOB('GATHER_STATS_JOB');
复制代码

2、重新创建统计信息收集任务

EXEC DBMS_SCHEDULER.CREATE_JOB(
'GATHER_STATS_JOB',
'PLSQL_BLOCK',
'begin DBMS_STATS.GATHER_DATABASE_STATS(''GATHER AUTO'', 0.1, 1, ''FOR ALL COLUMNS SIZE AUTO'', ''GLOBAL'', TRUE, TRUE); end;',
0,
cast(TRUNC(SYSDATE+1) + 2/24 as timestamp),
'SYSDATE + 1',
NULL,
'DEFAULT_JOB_CLASS',
TRUE,
FALSE,
'automatic optimizer statistics collection'
);
复制代码

主要更改 GATHER_DATABASE_STATS 的第 2、3、5 个参数,分别表示:采样率、并行度、分区表收集策略(默认 ALL-收集表和分区,GLOBAL-只收集表,在分区表数据量巨大且分区数多的情况下影响收集任务完成时间

并行度是单个收集任务内部的并行度,非表之间的并行度,因此全库收集是串行的)

 

3、手工运行任务

EXEC DBMS_SCHEDULER.RUN_JOB('GATHER_STATS_JOB');
复制代码

4、查看表统计信息收集时间

SELECT last_analyzed, owner, table_name FROM dba_tab_statistics ORDER BY 1 desc;
复制代码


发布于: 刚刚阅读数: 4
用户头像

YashanDB

关注

全自研国产新型大数据管理系统 2022-02-15 加入

还未添加个人简介

评论

发布
暂无评论
【YashanDB知识库】如何更改自动统计信息收集任务_数据库_YashanDB_InfoQ写作社区