-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathsession_redo_load.sql
83 lines (74 loc) · 2.98 KB
/
session_redo_load.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
declare
type stat_rec is record (inst_id number, sid number, statistic# number, value number);
type stat_table is table of stat_rec;
v_stat stat_table;
is_found integer;
n integer;
stat_name varchar2(100);
sess_name varchar2(255);
v_rec stat_rec;
begin
dbms_output.enable(20000);
select inst_id, sid, statistic#, value bulk collect into v_stat from gv$sesstat where statistic# in (select statistic# from gv$statname where name in ('redo size')) and value != 0;
dbms_lock.sleep(30);
for c in (select inst_id, sid, statistic#, value from gv$sesstat where statistic# in (select statistic# from gv$statname where name in ('redo size')) and value != 0) loop
is_found := 0;
for i in v_stat.first .. v_stat.last loop
if v_stat(i).inst_id = c.inst_id and v_stat(i).sid = c.sid and v_stat(i).statistic# = c.statistic# then
v_stat(i).value := c.value - v_stat(i).value;
is_found := 1;
end if;
end loop;
n := v_stat.last + 1;
if is_found = 0 then
v_stat.extend(1);
v_stat(n).inst_id := c.inst_id;
v_stat(n).sid := c.sid;
v_stat(n).statistic# := c.statistic#;
v_stat(n).value := c.value;
end if;
end loop;
for i in v_stat.first .. v_stat.last loop
for j in i+1 .. v_stat.last loop
if v_stat(j).value > v_stat(i).value then
v_rec := v_stat(j);
v_stat(j) := v_stat(i);
v_stat(i) := v_rec;
end if;
end loop;
end loop;
for i in 1 .. least(v_stat.count,30) loop
if v_stat(i).value > 0 then
begin
select sn.statistic#||' '||sn.name into stat_name from gv$statname sn where sn.inst_id = v_stat(i).inst_id and sn.statistic# = v_stat(i).statistic#;
/*
select decode(v_stat(i).statistic#,
589,'DB -> CLNT',
590,'DB <- CLNT',
592,'DB -> LINK ',
593,'DB <- LINK',
595,'VC -> CLNT',
596,'VC <- CLNT',
597,'VC -> LINK',
598,'VC <- LINK',
'UNKNOWN'
) into stat_name from dual;
*/
select s.username||'/'||s.machine||'/'||s.program||'/'||s.module||'/'||s.action into sess_name
from gv$session s where s.inst_id = v_stat(i).inst_id and s.sid = v_stat(i).sid;
dbms_output.put_line(v_stat(i).inst_id||' '||to_char(v_stat(i).sid,'99999')||' '||to_char(v_stat(i).value,'99999999999')||' '||stat_name||' '||sess_name);
exception when others then
null;
end;
end if;
end loop;
end;
--select * from gv$statname where statistic# in (589,590,592,593,595,596,597,598)
--select * from gv$statname where lower(name) like '%bytes%'
--select * from gv$sysstat
--select * from gv$statname where upper(name) like '%REDO%'
--select * from gv$sesstat ss, gv$statname sn, gv$session s
--where sn.statistic# in (589,590,592,593,595,596,597,598)
--and ss.inst_id = sn.inst_id and ss.statistic# = sn.statistic#
--and s.inst_id = ss.inst_id and s.sid = ss.sid
--order by ss.value desc