当前位置:网站首页>Oracle AWR 报告脚本:SQL ordered by Elapsed Time
Oracle AWR 报告脚本:SQL ordered by Elapsed Time
2022-07-26 11:58:00 【墨天轮】
以下是 Oracle AWR 报告中,SQL ordered by Elapsed Time 部分的计算语句:
/****************************************************************************************SQL ordered by Elapsed Time Resources reported for PL/SQL code includes the resources used by all SQL statements called by the code. % Total DB Time is the Elapsed Time of the SQL statement divided into the Total Database Time multiplied by 100 %Total - Elapsed Time as a percentage of Total DB time %CPU - CPU Time as a percentage of Elapsed Time %IO - User I/O Time as a percentage of Elapsed Time Captured SQL account for 75.8% of Total DB Time (s): 214,223 Captured PL/SQL account for 0.5% of Total DB Time (s): 214,223 ****************************************************************************************/select dbid, db_name, instance_number, inst_name, begin_snap_id, end_snap_id, elapsed, (SELECT e.VALUE-b.value as diff_value FROM DBA_HIST_SYS_TIME_MODEL B, DBA_HIST_SYS_TIME_MODEL E WHERE e.dbid = b.dbid and e.instance_number = b.instance_number and e.STAT_ID = b.STAT_ID and B.DBID = base_info.dbid AND B.INSTANCE_NUMBER = base_info.instance_number AND B.SNAP_ID = base_info.begin_snap_id AND E.SNAP_ID = base_info.end_snap_id AND B.STAT_NAME = 'DB time' ) as db_time, (SELECT sum(E.VALUE)-sum(B.VALUE) as STAT_TXN FROM DBA_HIST_SYSSTAT B, DBA_HIST_SYSSTAT E WHERE b.dbid = e.dbid and b.instance_number = e.instance_number and b.STAT_ID = e.STAT_ID AND E.DBID = base_info.dbid and e.instance_number = base_info.instance_number and b.snap_id = base_info.begin_snap_id and e.snap_id = base_info.end_snap_id AND e.STAT_NAME in ('user rollbacks','user commits') ) as transaction_count from (with db_info as (select d.dbid dbid, d.name db_name, i.instance_number instance_number, i.instance_name inst_name from v$database d, v$instance i), snap_info as (select c.*, EXTRACT(DAY FROM c.max_end_interval_time - c.min_end_interval_time) * 86400 + EXTRACT(HOUR FROM c.max_end_interval_time - c.min_end_interval_time) * 3600 + EXTRACT(MINUTE FROM c.max_end_interval_time - c.min_end_interval_time) * 60 + EXTRACT(SECOND FROM c.max_end_interval_time - c.min_end_interval_time) ELAPSED from (select min(snap_id) begin_snap_id, max(snap_id) end_snap_id, min(END_INTERVAL_TIME) as min_end_interval_time, max(END_INTERVAL_TIME) as max_end_interval_time from dba_hist_snapshot sn where sn.begin_interval_time >= trunc(sysdate) - 1 and sn.begin_interval_time < sysdate) c ) select * from db_info, snap_info) base_info; select * from (select to_char(nvl((sqt.elap / 1000000), to_number(null)),'9,999,990') as "Elapsed Time (s)", to_char(nvl((sqt.cput / 1000000), to_number(null)),'9,999,990') as "CPU Time (s)", to_char(sqt.exec,'999,999,999') as "Executions", to_char(decode(sqt.exec,0, to_number(null),(sqt.elap / sqt.exec / 1000000)),'9999990.0') as "Elapsed Time per Exec (s)",--10g中用 Elap per Exec (s) 表示 to_char((100 * (sqt.elap / &db_time )),9990.0) as "% Total DB Time",--11g中的"%Total%" decode(sqt.elap, 0, to_number(null), (100 * (sqt.cput / sqt.elap))) as "%CPU", decode(sqt.elap, 0, to_number(null), (100 * (sqt.iowt / sqt.elap))) as "%IO", sqt.sql_id as "SQL Id", decode(sqt.module,null, null, 'Module: ' || sqt.module) as "SQL Module", nvl(dbms_lob.substr(st.sql_text,1400,1), to_clob('** SQL Text Not Available **')) as "SQL Text" --norm_val 直接执行时可去掉dbms_lob.substr() from (select sql_id, max(module) module, sum(elapsed_time_delta) elap, sum(cpu_time_delta) cput, sum(executions_delta) exec, sum(iowait_delta) iowt from dba_hist_sqlstat where /*dbid = &dbid*/ instance_number = &instance_number and &begin_snap_id < snap_id and snap_id <= &end_snap_id group by sql_id ) sqt, dba_hist_sqltext st where st.sql_id(+) = sqt.sql_id /*and st.dbid(+) = 3929621523*/ order by nvl(sqt.elap, -1) desc, sqt.sql_id) where rownum < 65 and (rownum <= 10 or "% Total DB Time" > 1.0);边栏推荐
- Acwing727. Diamond pattern
- Harbor2.2 quick check of user role permissions
- Ga-rpn: recommended area network for guiding anchors
- Real time synchronization and conversion of massive data based on Flink CDC
- 3.1 create menu and game page - up
- Flutter 学习之路
- pytest接口自动化测试框架 | fixture调用fixture
- Codepoint 58880 not found in font, aborting. Flutter build APK reports an error
- 剑指 Offer 24. 反转链表
- 虚拟偶像代言产品出问题谁负责? 且听律师分析
猜你喜欢

Marriage seeking story

pytest接口自动化测试框架 | pytest配置文件

Flink 在 讯飞 AI 营销业务的实时数据分析实践

【附下载】一款强大的Web自动化漏洞扫描工具——Xray

An online duplicate of a hidden bug

Real time synchronization and conversion of massive data based on Flink CDC

How RFID works

专访即构科技李凯:音视频的有趣、行业前沿一直吸引着我

Yuancosmos daily | yuancosmos social app "Party Island" product off the shelves; Guangzhou Nansha yuanuniverse industrial agglomeration zone was unveiled; The inter ministerial joint conference system

向日葵远程控制为何采用BGP服务器?自动最优路线、跨运营商高速传输
随机推荐
Pytest interface automation test framework | setup and teardown functions of pytest
There are various signs that apple is expected to support AV1
MILA旗下初创企业Ubenwa获得250万美元投资,研究婴儿健康AI诊断
V01 - XX,记录美好生活从日志开始
【附下载】一款强大的Web自动化漏洞扫描工具——Xray
音视频+
On the construction and management of low code technology in logistics transportation platform
连锁店收银系统如何帮助鞋店管理好分店?
Use of strjoin function in MATLAB
音视频技术开发周刊 | 255
以太网驱动详解之RMII、SMII、GMII、RGMII接口
Understand the string class
基于STM32的SIM900A发送中文和英文短信
JSJ-3/AC220V时间继电器
Li Kai: the interesting and cutting-edge audio and video industry has always attracted me
Cohere博客:在生产环境中运行大型语言模型-推理框架概览
《多线程下ThreadLocal使用场景实例》
【倒计时10天】腾讯云音视频专场即将见面,千元大奖等你来拿!
pytest接口自动化测试框架 | pytest的setup和teardown函数
Here blog: running a large language model in a production environment - overview of the reasoning framework