Files
oracle/tpt/ash/bshortmon_logfilesync.sql

49 lines
1.7 KiB
MySQL
Raw Normal View History

2026-03-12 21:23:47 +01:00
-- Copyright 2018 Tanel Poder. All rights reserved. More info at http://tanelpoder.com
-- Licensed under the Apache License, Version 2.0. See LICENSE.txt for terms & conditions.
COL wait_class FOR a15
COL event FOR a55
COL time_range HEAD "WAIT_TIM_BUCKET_US+" FOR 999,999,999,999
COL avg_wait_us HEAD "AVG_WAIT_IN_BKT_US" FOR 999,999,999,999
COL pct_event FOR a9
COL pct_total FOR a9
BREAK ON event SKIP 1 DUPLICATES
-- TODO: ignore latest sample (0 waits)
SELECT
session_state state
, wait_class
, event
, ROUND(AVG(time_waited)) avg_wait_us
, POWER(2,TRUNC(LOG(2,CASE WHEN time_waited < 1 THEN NULL ELSE time_waited END))) time_range
, COUNT(*) samples
, LPAD(TO_CHAR(TO_NUMBER(ROUND(RATIO_TO_REPORT(COUNT(*)) OVER (PARTITION BY session_state, wait_class, event) * 100, 1), 999.9))||' %',8) pct_event
, '|'||RPAD( NVL( LPAD('#', ROUND(RATIO_TO_REPORT(COUNT(*)) OVER (PARTITION BY session_state, wait_class, event) * 10), '#'), ' '), 10,' ')||'|' pct_event_vis
, LPAD(TO_CHAR(TO_NUMBER(ROUND(RATIO_TO_REPORT(COUNT(*)) OVER () * 100, 1), 999.9))||' %',8) pct_total
, '|'||RPAD( NVL( LPAD('#', ROUND(RATIO_TO_REPORT(COUNT(*)) OVER () * 10), '#'), ' '), 10,' ')||'|' pct_total_vis
FROM
dba_hist_ash_aug
--gv$active_session_history
--DBA_HIST_ACTIVE_SESS_HISTORY
WHERE
&2
AND sample_time BETWEEN &3 AND &4
--AND sample_time BETWEEN TIMESTAMP'2013-10-01 13:54:00' AND TIMESTAMP'2013-10-01 13:55:00'
AND (UPPER(wait_class) LIKE UPPER('%&1%') OR UPPER(event) LIKE UPPER('%&1%'))
--AND program LIKE 'sqlplus%'
GROUP BY
session_state
, wait_class
, event
, POWER(2,TRUNC(LOG(2,CASE WHEN time_waited < 1 THEN NULL ELSE time_waited END)))
ORDER BY
session_state
, wait_class
, event
, time_range NULLS FIRST
, samples DESC
/