-
Notifications
You must be signed in to change notification settings - Fork 1.3k
/
v_vacuum_summary.sql
62 lines (59 loc) · 3.06 KB
/
v_vacuum_summary.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
/**********************************************************************************************
Purpose: View to flatten stl_vacuum table and provide details like vacuum start and
end times, current status, changed rows and freed blocks all in one row
Current Version: 1.04
History:
Version 1.01
2017-12-24 adedotua created
Version 1.02
2018-12-22 adedotua updated view to account for background auto vacuum process
Version 1.03
2018-12-30 adedotua fixed join condition to make vacuum on dropped tables visible
Version 1.04
2019-04-30 adedotua added is_auto_vacuum flag to indicate whether vacuum was auto vacuum
Version 1.05
2019-10-09 adedotua set vac_end_status as null for autovacuum if end status is unknown
Version 1.06
2023-02-09 add is_recluster and aborted columns
**********************************************************************************************/
CREATE OR REPLACE VIEW admin.v_vacuum_summary as SELECT a.userid
,a.xid
,d.datname::varchar AS database_name
,a.table_id
,c.name::varchar AS tablename
,a.status::varchar AS vac_start_status
,CASE WHEN a.status ilike 'skipped%' THEN null::TEXT
WHEN f.xid IS NOT NULL THEN 'Running'::TEXT
WHEN g.aborted = 1 THEN 'Aborted'::TEXT
WHEN b.status IS NULL and a.status not ilike '%[VacuumBG]%' THEN 'Failed'::TEXT
ELSE b.status::TEXT
END::TEXT AS vac_end_status
,a.eventtime AS vac_start_time
,CASE WHEN g.aborted = 1 THEN g.endtime
ELSE b.eventtime
END AS vac_end_time
,CASE WHEN f.xid IS NOT NULL THEN datediff(s,vac_start_time,getdate())
WHEN b.eventtime IS NOT NULL THEN datediff(s,vac_start_time,vac_end_time)
ELSE NULL
END AS vac_duration_secs
,a."rows" AS vac_start_rows
,b."rows" AS vac_end_rows
,a."rows" - b."rows" AS vac_deleted_rows
,a.sortedrows AS vac_start_sorted_rows
,b.sortedrows AS vac_end_sorted_rows
,a."blocks" AS vac_start_blocks
,b."blocks" AS vac_end_blocks
,(b."blocks" - a."blocks") AS vac_block_diff
,NVL(e.empty_blk_cnt,0) AS empty_blk_cnt
,CASE WHEN a.status ilike '%[VacuumBG]%' THEN true ELSE false END is_auto_vacuum
,a.is_recluster
,g.aborted
FROM
(SELECT * FROM stl_vacuum WHERE status not ilike '%Finished%') a
LEFT JOIN stl_vacuum b on (a.xid,a.table_id) = (b.xid,b.table_id) and a.eventtime < b.eventtime
LEFT JOIN (SELECT id,name,db_id FROM stv_tbl_perm WHERE slice = 0) c ON a.table_id = c.id
LEFT JOIN pg_database d ON c.db_id::oid = d.oid
LEFT JOIN (SELECT tbl,COUNT(*) AS empty_blk_cnt FROM stv_blocklist WHERE num_values = 0 GROUP BY tbl) e ON a.table_id = e.tbl
LEFT JOIN (SELECT xid FROM svv_transactions WHERE lockable_object_type = 'transactionid') f on a.xid=f.xid
LEFT JOIN (select xid,max(endtime) as endtime,max(aborted) as aborted from stl_query group by 1) g on a.xid = g.xid
ORDER BY a.xid;