2014-09-17 13:23:48 +02:00

91 lines
2.2 KiB
SQL

--------------------------------------------------------------------------------
--
-- Author: Tanel Poder
-- Copyright: (c) http://www.tanelpoder.com
--
-- Notes: This software is provided AS IS and doesn't guarantee anything
-- Proofread before you execute it!
--
--------------------------------------------------------------------------------
set linesize 156
set pagesize 5000
set verify off
select
to_char(a.snaptime, 'YYYYMMDD HH24:MI:SS') snapshot_begin,
to_char(b.snaptime, 'YYYYMMDD HH24:MI:SS') snapshot_end,
(b.snaptime - a.snaptime)*86400 dur_sec,
(b.snaptime - a.snaptime)*86400/60 dur_min
from
(select snaptime from sawr$snapshots where snapid = &2) a,
(select snaptime from sawr$snapshots where snapid = &3) b
/
-- reports all sessions wait events
col ms_per_sec head ms/|sec for 999999
col pct_per_sec head %|sec for 999999
col wait_ms head "ms in|snapshot" for 9999999999
col waits head "Waits in|snapshot" for 99999999
col event_name head "Event Name" for a45
col avgdelta head "Avg|Wait" for 990.99 justify right
col avg_wait_ms head "Avg Wait|ms" for 9999990 justify right
col AVGDLT% head "%" for a1
col %TOTAL head "% Total" for a12 justify right
col &1 word_wrap
-- break on sid skip 1 on audsid
break on &1 skip 1
select
&1,
name EVENT_NAME,
decode(lower('&_tptmode'),'html','','|')||
rpad(
nvl(
lpad('#',
ceil( (nvl(round(sum(us_per_sec/1000000),2),0))*10 ),
'#'),
' '),
10,' ')
||decode(lower('&_tptmode'),'html','','|') "%TOTAL",
avg(us_per_sec)/1000 ms_per_sec,
sum(wait_us)/1000 wait_ms,
sum(waits),
sum(wait_us/decode(waits,0,1,waits))/1000 avg_wait_ms
from
sawr$sess_event_delta
where
begin_snapid = &2
and end_snapid = &3
and wait_us != 0
group by
&1, name
order by
&1, ms_per_sec desc
/
-- sum(wait_us)/1000 wait_ms,
-- sum(waits)
-- sum(wait_us)/sum(decode(waits,0,1,waits)/1000)) avg_wait_ms
-- to_number(decode(avgdelta,0,null,avgdelta)) avgdlt,
-- avgdelta,
-- decode(avgdelta,0,null,'%') "AVGDLT%"
-- round(us_per_sec/10000,2) pct_per_sec,
-- intrvl,
-- '|'||
-- rpad(
-- nvl(
-- lpad('#',
-- ceil( (nvl(round(sum(us_per_sec/1000000),2),0))*10 ),
-- '#'),
-- ' '),
-- 10,' ')
-- ||'|' "%TOTAL",