-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsenc_tde_ops_csv.sql
80 lines (75 loc) · 3.58 KB
/
senc_tde_ops_csv.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
--------------------------------------------------------------------------------
-- OraDBA - Oracle Database Infrastructure and Security, 5630 Muri, Switzerland
--------------------------------------------------------------------------------
-- Name......: senc_tde_ops_csv.sql
-- Author....: Stefan Oehrli (oes) [email protected]
-- Editor....: Stefan Oehrli
-- Date......: 2024.03.21
-- Revision..:
-- Purpose...: Show TDE operations from V$SESSION_LONGOPS as CSV
-- Notes.....:
-- Reference.: Requires access to V$SESSION_LONGOPS
-- License...: Apache License Version 2.0, January 2004 as shown
-- at http://www.apache.org/licenses/
--------------------------------------------------------------------------------
-- start to spool
SPOOL senc_tde_ops_csv.log
-- format SQLPlus output and behavior
SET markup csv ON
ALTER SESSION SET nls_date_format='DD.MM.YYYY HH24:MI:SS';
ALTER SESSION SET nls_timestamp_format='DD.MM.YYYY HH24:MI:SS';
SELECT
sid,
serial#,
to_number(regexp_substr(message, 'data file (\d+)', 1, 1, NULL, 1)) as file_id,
start_time,
start_time + (time_remaining/86400) AS end_time,
elapsed_seconds,
lpad(CASE
WHEN elapsed_seconds < 60 THEN elapsed_seconds || 's'
WHEN elapsed_seconds < 3600 THEN
FLOOR(elapsed_seconds / 60) || 'm ' || MOD(elapsed_seconds, 60) || 's'
WHEN elapsed_seconds < 86400 THEN
FLOOR(elapsed_seconds / 3600) || 'h ' || FLOOR(MOD(elapsed_seconds, 3600) / 60) || 'm ' || MOD(elapsed_seconds, 60) || 's'
ELSE
FLOOR(elapsed_seconds / 86400) || 'd ' || FLOOR(MOD(elapsed_seconds, 86400) / 3600) || 'h ' || FLOOR(MOD(elapsed_seconds, 3600) / 60) || 'm ' || MOD(elapsed_seconds, 60) || 's'
END,15,' ') AS formatted_elapsed_time,
sofar/elapsed_seconds as throughput,
lpad(CASE
WHEN sofar/elapsed_seconds < POWER(1024, 1) THEN ROUND(sofar/elapsed_seconds, 2) || ' B'
WHEN sofar/elapsed_seconds < POWER(1024, 2) THEN ROUND(sofar/elapsed_seconds / POWER(1024, 1), 2) || ' KB'
WHEN sofar/elapsed_seconds < POWER(1024, 3) THEN ROUND(sofar/elapsed_seconds / POWER(1024, 2), 2) || ' MB'
WHEN sofar/elapsed_seconds < POWER(1024, 4) THEN ROUND(sofar/elapsed_seconds / POWER(1024, 3), 2) || ' GB'
ELSE ROUND(sofar/elapsed_seconds / POWER(1024, 4), 2) || ' TB'
END,12,' ') AS throughput_formatted,
sofar,
lpad(CASE
WHEN sofar < POWER(1024, 1) THEN ROUND(sofar, 2) || ' B'
WHEN sofar < POWER(1024, 2) THEN ROUND(sofar / POWER(1024, 1), 2) || ' KB'
WHEN sofar < POWER(1024, 3) THEN ROUND(sofar / POWER(1024, 2), 2) || ' MB'
WHEN sofar < POWER(1024, 4) THEN ROUND(sofar / POWER(1024, 3), 2) || ' GB'
ELSE ROUND(sofar / POWER(1024, 4), 2) || ' TB'
END,12,' ') AS sofar_formatted,
totalwork,
lpad(CASE
WHEN totalwork < POWER(1024, 1) THEN ROUND(totalwork, 2) || ' B'
WHEN totalwork < POWER(1024, 2) THEN ROUND(totalwork / POWER(1024, 1), 2) || ' KB'
WHEN totalwork < POWER(1024, 3) THEN ROUND(totalwork / POWER(1024, 2), 2) || ' MB'
WHEN totalwork < POWER(1024, 4) THEN ROUND(totalwork / POWER(1024, 3), 2) || ' GB'
ELSE ROUND(totalwork / POWER(1024, 4), 2) || ' TB'
END,12,' ') AS totalwork_formatted,
sofar/totalwork*100 as percent,
CASE
WHEN time_remaining>0 THEN 'running'
ELSE 'finished'
END AS status
,opname
FROM
v$session_longops
WHERE opname LIKE 'TDE%'
ORDER BY
file_id ASC,
status DESC;
SET markup csv OFF
SPOOL OFF
-- EOF -------------------------------------------------------------------------