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

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

一、创建用户并赋权

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;

相关文章:

  • IWPA_CEC2005
  • 网络安全行业有哪些公司
  • 网络安全评估指南 网络安全评价体系
  • MySQL数据类型
  • 全新的Android UI框架Jetpack Compose
  • 介绍 Kamailio 的 kamcmd
  • 如何进行市场趋势分析:方法与案例指南
  • 代码笔记插件
  • 跟着 Lua 5.1 官方参考文档学习 Lua (3)
  • 【HarmonyOS Next】鸿蒙应用进程和线程详解
  • WSL2使用Kind创建K8S集群时出现IPV6网络创建失败
  • Java 面试笔记 - Java基础
  • vue组件二次封装
  • 关于redis的主从复制(下)
  • 【深度学习在图像配准中的应用与挑战】
  • 详细介绍Tess4J的使用:从PDF到图像的OCR技术实现
  • Nacos Derby 远程命令执行漏洞修复建议
  • DeepSeek学习资料
  • 强化学习-价值学习算法
  • 电路元器件知识:稳压二极管
  • 印度证实印巴已同意停火
  • 明星同款撕拉片,为何能炒到三四百一张?
  • 王受文已任全国工商联党组成员
  • 东洋学人|滨田青陵:近代日本考古学第一人
  • 越秀地产前4个月销售额约411.2亿元,达年度销售目标的34.1%
  • 新疆生产建设兵团草湖项目区副主任宋全伟接受审查调查