定期自动统计大表执行情况

news/2025/2/21 6:55:39

一、创建用户并赋权

create user dbtj identified by oracle default tablespace OGGTBS;

grant connect,resource to dbtj;

grant select any dictionary to dbtj;

grant create job to dbtj;

grant manage scheduler to dbtj;

二、创建存储表

1、连接到新建用户

conn dbtj/oracle

2、按大表2千万为维度,统计出大表,再根据大表找到最近一天的sql,统计其执行效率(毫秒),创建数据存储表

create table dbtj.dbtj_tab as

select to_char(b.end_interval_time, 'yyyy-mm-dd-hh24') as datet,

SQL_ID,

sum(a.executions_delta) exec_d,

sum(a.buffer_gets_delta) buffer_d,

sum(a.disk_reads_delta) disk_d,

round(sum(a.elapsed_time_delta / 1000000), 3) et_d,

round(decode(sum(a.executions_delta),

0,

sum(a.elapsed_time_delta),

sum(a.elapsed_time_delta / 1000) /

sum(a.executions_delta)),

2) et_onetime

from dba_hist_sqlstat a, dba_hist_snapshot b

where a.snap_id = b.snap_id

and a.instance_number = b.instance_number

and a.sql_id IN

(SELECT DISTINCT (SQL_ID)

FROM GV$SQL_PLAN SP

WHERE (sp.OBJECT_OWNER, sp.OBJECT_NAME) in

(select owner, table_name

from dba_tables

where num_rows >= 20000000

and owner not in ('SYS', 'SYSTEM')))

AND B.end_interval_time >= SYSDATE - 6/24

group by to_char(b.end_interval_time, 'yyyy-mm-dd-hh24'), SQL_ID

having(sum(a.executions_delta)) > 0

order by 1;

三、创建存储过程,将第二步的查询结果插入到数据表dbtj_tab

create or replace procedure dbtj_proc

as

begin

insert into dbtj.dbtj_tab

select to_char(b.end_interval_time, 'yyyy-mm-dd-hh24') as datet,

SQL_ID,

sum(a.executions_delta) exec_d,

sum(a.buffer_gets_delta) buffer_d,

sum(a.disk_reads_delta) disk_d,

round(sum(a.elapsed_time_delta / 1000000), 3) et_d,

round(decode(sum(a.executions_delta),

0,

sum(a.elapsed_time_delta),

sum(a.elapsed_time_delta / 1000) /

sum(a.executions_delta)),

2) et_onetime

from dba_hist_sqlstat a, dba_hist_snapshot b

where a.snap_id = b.snap_id

and a.instance_number = b.instance_number

and a.sql_id IN

(SELECT DISTINCT (SQL_ID)

FROM GV$SQL_PLAN SP

WHERE (sp.OBJECT_OWNER, sp.OBJECT_NAME) in

(select owner, table_name

from dba_tables

where num_rows >= 20000000

and owner not in ('SYS', 'SYSTEM')))

AND B.end_interval_time >= SYSDATE - 6/24

group by to_char(b.end_interval_time, 'yyyy-mm-dd-hh24'), SQL_ID

having(sum(a.executions_delta)) > 0

order by 1;

commit;

end;

四、创建定时任务,每天1、7、13、19 统计

begin

dbms_scheduler.create_job(

job_name =>'dbtj_job',

job_type =>'STORED_PROCEDURE',

JOB_ACTION =>'dbtj_proc',

START_DATE =>TO_TIMESTAMP_TZ('2022-07-11 22:10:00 +8:00','YYYY-MM-DD HH24:MI:SS TZH:TZM'),

REPEAT_INTERVAL =>'FREQ=DAILY;BYHOUR=01,07,13,19',

ENABLED =>TRUE);

END;

五、测试

begin

dbtj_proc;

end;


begin

dbms_scheduler.enable('dbtj_job');

end;


begin

dbms_scheduler.run_job('dbtj_job');

end;


BEGIN

DBMS_SCHEDULER.DROP_JOB('dbtj_job');

END;


select * from dbtj.dbtj_tab;

六、结果展示
 

dbtj.dbtj_tab

select datet as "时间",sql_id,exec_d as "执行次数",et_onetime as "每次耗时(毫秒)" from dbtj.dbtj_tab where datet >= to_char(sysdate-1,'yyyy-mm-dd-hh24') order by 1;


http://www.niftyadmin.cn/n/5860411.html

相关文章

风险价值VaR、CVaR与ES

风险价值VaR、CVaR与ES 一、VaR风险价值1. VaR的定义及基本概念2.VaR的主要性质3.风险价值的优缺点 二、CVaR条件风险价值与ES预期损失1.CVaR的基本概念2.性质3.ES预期损失 一、VaR风险价值 1. VaR的定义及基本概念 20年前,JP的大佬要每天下午收盘后的4:15在桌上看…

游戏引擎学习第114天

打开内容并回顾 目前正在讨论一个非常重要的话题——优化。当代码运行太慢,无法达到所需性能时,我们该怎么办。昨天,我们通过在代码中添加性能计数器,验证了一些性能分析的数据,这些计数器帮助我们了解每个操作需要的…

docker 改了镜像源为阿里云,还是下载失败

我是windows系统,在学习docker,刚开始执行docker run hello-world还是失败,然后改了镜像源为阿里云,还是失败,后来去查资料,除了阿里云还配置了很多其他镜像源,才好使 "registry-mirrors&q…

TOGAF之架构标准规范-信息系统架构 | 应用架构

TOGAF是工业级的企业架构标准规范,信息系统架构阶段是由数据架构阶段以及应用架构阶段构成,本文主要描述信息系统架构阶段中的应用架构阶段。 如上所示,信息系统架构(Information Systems Architectures)在TOGAF标准规…

源码方式安装llama.cpp及调试

llama.cpp源码方式安装和调试配置 构建和编译 注意这里是cuda,且要开启debug模式 cmake -B build -DGGML_CUDAON -DCMAKE_BUILD_TYPEDebug cmake --build build --config Debug正在编译: 配置launch.json用于调式: 要根据自己的环境路径…

【Java】代理模式

代理模式 代理模式是指给某一个对象提供一个代理,并由代理对象来控制对真实对象的访问 代理模式是一种结构型设计模式 背景 如果不采用代理,对一个类的多个方法进行监控时,重复的代码总是重复出现,不但破坏了原方法,…

微信小程序:多菜单栏设计效果

一、实现效果 二、代码 wxml 编辑前端界面,步骤 菜单逻辑: 逐步取出数组中的项,首先取出顶部菜单项,然后选中后取出选中的底部数据(左侧菜单+右侧内容),然后点击左侧菜单取出选中的左侧菜单对应的右侧内容 ①这里我的数据是全部封装到一个数组对象的,首先我的循环…

Kafka Connect 数据格式转换器

Kafka Connect 支持以下数据格式转换器: 1. Avro Converter 用途:将数据序列化为 Avro 格式。特点:支持模式(Schema),适合需要严格数据结构的场景。配置示例:key.converter=io.confluent.connect.avro.AvroConverter key.converter.schema.registry.url=http://schema-…