oracle-查询指定时间范围内最消耗资源的前100条sql

简介:
SET SERVEROUT ON SIZE UNLIMITED;
REM 查询指定时间范围内最消耗资源,按照elapsed_time、cpu_time或者buffer_gets,gets_per_row排序的前100条sql
PRO
PRO
PRO 查询指定时间范围内最消耗资源,按照elapsed_time、cpu_time或者buffer_gets,gets_per_row排序的前100条sql
SET TERM ON ECHO OFF;
SET VERIFY off;
ACCEPT begintime CHAR PROMPT 'Enter begin_time(eg:201805030001): '
ACCEPT endtime CHAR PROMPT 'Enter end_time(eg:201805031001): '
ACCEPT rank CHAR DEFAULT 'time_rank' PROMPT 'Enter Rank column(eg:time_rank,cputime_rank,gets_rank,gets_per_row_rank): '
col begintime new_value begintime noprint
col endtime new_value endtime noprint

set line 250
set pages 150
col begin_time for a12
col end_time for a12
col sql_id for a15
col plans_diff for 99
col cputime_per_exec for 999990.999
col time_per_exec for 999990.999
col gets_per_exec for 999999999
col rows_per_exec for 99999990.99
col cputime_delta for 99999990.999
col time_delta for 999999990.999
col exec_delta for 9999999999999
col gets_d for 9999999999
col rows_d for 999999999
col cputime_rank for 9999
col time_rank for 9999
col gets_rank for 9999
col gets_per_row_rank for 9999

spool /tmp/tmp.sql
select * from (
select 
    a.sql_id sql_id,
    to_char(min(b.begin_interval_time),'yyyymmddhh24') begin_time,
    to_char(max(b.end_interval_time),'yyyymmddhh24') end_time,
    count(distinct(a.plan_hash_value)) plans_diff,
    round(decode(sum(a.EXECUTIONS_DELTA),0,sum(a.CPU_TIME_DELTA/1000000),sum(a.CPU_TIME_DELTA/1000000)/sum(a.EXECUTIONS_DELTA)),3) cputime_per_exec,
    round(decode(sum(a.EXECUTIONS_DELTA),0,sum(a.ELAPSED_TIME_DELTA/1000000),sum(a.ELAPSED_TIME_DELTA/1000000)/sum(a.EXECUTIONS_DELTA)),3) time_per_exec,
    round(decode(sum(a.EXECUTIONS_DELTA),0, sum(a.BUFFER_GETS_DELTA ), sum(a.BUFFER_GETS_DELTA )/sum(a.EXECUTIONS_DELTA)),0) gets_per_exec,
    round(decode(sum(a.EXECUTIONS_DELTA),0,sum(a.ROWS_PROCESSED_DELTA),sum(a.ROWS_PROCESSED_DELTA)/sum(a.EXECUTIONS_DELTA)),2) rows_per_exec,
    round(sum(a.CPU_TIME_DELTA/1000000),3) cputime_delta,
    round(sum(a.ELAPSED_TIME_DELTA/1000000),3) time_delta,
    sum(a.EXECUTIONS_DELTA) exec_delta,
    sum(a.BUFFER_GETS_DELTA ) gets_delta,    
    sum(a.ROWS_PROCESSED_DELTA) rows_delta,
    DENSE_RANK() OVER (ORDER BY decode(sum(a.EXECUTIONS_DELTA),0,sum(a.CPU_TIME_DELTA/1000000),sum(a.CPU_TIME_DELTA/1000000)/sum(a.EXECUTIONS_DELTA)) DESC) cputime_rank,
    DENSE_RANK() OVER (ORDER BY decode(sum(a.EXECUTIONS_DELTA),0,sum(a.ELAPSED_TIME_DELTA/1000000),sum(a.ELAPSED_TIME_DELTA/1000000)/sum(a.EXECUTIONS_DELTA)) DESC) time_rank,
    DENSE_RANK() OVER (ORDER BY decode(sum(a.EXECUTIONS_DELTA),0, sum(a.BUFFER_GETS_DELTA), sum(a.BUFFER_GETS_DELTA )/sum(a.EXECUTIONS_DELTA)) DESC) gets_rank,
    DENSE_RANK() OVER (ORDER BY decode(sum(a.ROWS_PROCESSED_DELTA),0, sum(a.BUFFER_GETS_DELTA)/sum(EXECUTIONS_DELTA), sum(a.BUFFER_GETS_DELTA )/sum(a.ROWS_PROCESSED_DELTA)) DESC) gets_per_row_rank
from  
    dba_hist_sqlstat a,
    dba_hist_snapshot b
where
    a.snap_id = b.snap_id
and
    b.BEGIN_INTERVAL_TIME between to_date('&begintime','yyyymmddhh24mi') and to_date('&endtime','yyyymmddhh24mi')
and 
    a.executions_delta > 0    
group by 
    a.sql_id
having 
   sum(a.EXECUTIONS_DELTA) > round(to_number(to_date('&begintime','yyyymmddhh24mi') - to_date('&endtime','yyyymmddhh24mi')) * 24)
)
where &rank <= 100  
order by &rank,time_rank,cputime_rank ,gets_per_row_rank,gets_rank;
spool off
目录
相关文章
|
2月前
|
SQL Oracle 关系型数据库
如何在 Oracle 中配置和使用 SQL Profiles 来优化查询性能?
在 Oracle 数据库中,SQL Profiles 是优化查询性能的工具,通过提供额外统计信息帮助生成更有效的执行计划。配置和使用步骤包括:1. 启用自动 SQL 调优;2. 手动创建 SQL Profile,涉及收集、执行调优任务、查看报告及应用建议;3. 验证效果;4. 使用 `DBA_SQL_PROFILES` 视图管理 Profile。
|
5月前
|
SQL 监控 Oracle
Oracle SQL性能优化全面指南
在数据库管理领域,Oracle SQL性能优化是确保数据库高效运行和数据查询速度的关键
|
5月前
|
SQL 存储 Oracle
Oracle数据库SQL语句详解与应用指南
在数字化时代,数据库已成为各类企业和组织不可或缺的核心组件。Oracle数据库作为业界领先的数据库管理系统之一,广泛应用于各种业务场景。掌握Oracle数据库的SQL语句是数据库管理员、开发人员及运维人员的基本技能。本文将详细介绍Oracle数据库SQL语句的基本概念、语法、应用及最佳实践。一、Or
147 3
|
5月前
|
SQL Oracle 关系型数据库
Oracle SQL:了解执行计划和性能调优
Oracle SQL:了解执行计划和性能调优
141 1
|
8月前
|
SQL 分布式计算 DataWorks
DataWorks产品使用合集之使用API调用ODPS SQL时,出现资源被定时任务抢占,该怎么办
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
123 32
|
8月前
|
SQL Oracle 关系型数据库
MySQL、SQL Server和Oracle数据库安装部署教程
数据库的安装部署教程因不同的数据库管理系统(DBMS)而异,以下将以MySQL、SQL Server和Oracle为例,分别概述其安装部署的基本步骤。请注意,由于软件版本和操作系统的不同,具体步骤可能会有所变化。
629 3
|
8月前
|
SQL 存储 Oracle
TDengine 3.3.2.0 发布:新增 UDT 及 Oracle、SQL Server 数据接入
**TDengine 3.3.2.0 发布摘要** - 开源与企业版均强化性能,提升WebSocket、stmt模式写入与查询效率,解决死锁,增强列显示。 - taos-explorer支持geometry和varbinary类型。 - 企业版引入UDT,允许自定义数据转换。 - 新增Oracle和SQL Server数据接入。 - 数据同步优化,支持压缩,提升元数据同步速度,错误信息细化,支持表名修改。 - 扩展跨平台支持,包括麒麟、Euler、Anolis OS等。
188 0
|
6月前
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
8月前
|
SQL 存储 监控
SQL Server的并行实施如何优化?
【7月更文挑战第23天】SQL Server的并行实施如何优化?
198 13
|
8月前
|
SQL
解锁 SQL Server 2022的时间序列数据功能
【7月更文挑战第14天】要解锁SQL Server 2022的时间序列数据功能,可使用`generate_series`函数生成整数序列,例如:`SELECT value FROM generate_series(1, 10)。此外,`date_bucket`函数能按指定间隔(如周)对日期时间值分组,这些工具结合窗口函数和其他时间日期函数,能高效处理和分析时间序列数据。更多信息请参考官方文档和技术资料。
119 9

热门文章

最新文章

推荐镜像

更多