2002-07-20 00:58:14 -04:00
|
|
|
--
|
|
|
|
|
-- VACUUM
|
|
|
|
|
--
|
|
|
|
|
|
|
|
|
|
CREATE TABLE vactst (i INT);
|
|
|
|
|
INSERT INTO vactst VALUES (1);
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst VALUES (0);
|
|
|
|
|
SELECT count(*) FROM vactst;
|
|
|
|
|
DELETE FROM vactst WHERE i != 0;
|
|
|
|
|
SELECT * FROM vactst;
|
|
|
|
|
VACUUM FULL vactst;
|
|
|
|
|
UPDATE vactst SET i = i + 1;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst SELECT * FROM vactst;
|
|
|
|
|
INSERT INTO vactst VALUES (0);
|
|
|
|
|
SELECT count(*) FROM vactst;
|
|
|
|
|
DELETE FROM vactst WHERE i != 0;
|
2009-11-16 16:32:07 -05:00
|
|
|
VACUUM (FULL) vactst;
|
2002-07-20 00:58:14 -04:00
|
|
|
DELETE FROM vactst;
|
|
|
|
|
SELECT * FROM vactst;
|
|
|
|
|
|
2009-11-16 16:32:07 -05:00
|
|
|
VACUUM (FULL, FREEZE) vactst;
|
2010-02-07 23:33:55 -05:00
|
|
|
VACUUM (ANALYZE, FULL) vactst;
|
2009-11-16 16:32:07 -05:00
|
|
|
|
2010-01-06 00:31:14 -05:00
|
|
|
CREATE TABLE vaccluster (i INT PRIMARY KEY);
|
|
|
|
|
ALTER TABLE vaccluster CLUSTER ON vaccluster_pkey;
|
|
|
|
|
CLUSTER vaccluster;
|
|
|
|
|
|
2015-01-07 22:33:58 -05:00
|
|
|
CREATE FUNCTION do_analyze() RETURNS VOID VOLATILE LANGUAGE SQL
|
|
|
|
|
AS 'ANALYZE pg_am';
|
|
|
|
|
CREATE FUNCTION wrap_do_analyze(c INT) RETURNS INT IMMUTABLE LANGUAGE SQL
|
|
|
|
|
AS 'SELECT $1 FROM do_analyze()';
|
2015-01-12 15:13:28 -05:00
|
|
|
CREATE INDEX ON vaccluster(wrap_do_analyze(i));
|
|
|
|
|
INSERT INTO vaccluster VALUES (1), (2);
|
|
|
|
|
ANALYZE vaccluster;
|
2015-01-07 22:33:58 -05:00
|
|
|
|
2010-01-06 00:31:14 -05:00
|
|
|
VACUUM FULL pg_am;
|
|
|
|
|
VACUUM FULL pg_class;
|
|
|
|
|
VACUUM FULL pg_database;
|
|
|
|
|
VACUUM FULL vaccluster;
|
|
|
|
|
VACUUM FULL vactst;
|
|
|
|
|
|
2016-06-17 15:48:57 -04:00
|
|
|
VACUUM (DISABLE_PAGE_SKIPPING) vaccluster;
|
|
|
|
|
|
2010-01-06 00:31:14 -05:00
|
|
|
DROP TABLE vaccluster;
|
2002-07-20 00:58:14 -04:00
|
|
|
DROP TABLE vactst;
|
2017-03-07 11:24:51 -05:00
|
|
|
|
|
|
|
|
-- partitioned table
|
|
|
|
|
CREATE TABLE vacparted (a int, b char) PARTITION BY LIST (a);
|
|
|
|
|
CREATE TABLE vacparted1 PARTITION OF vacparted FOR VALUES IN (1);
|
|
|
|
|
INSERT INTO vacparted VALUES (1, 'a');
|
|
|
|
|
UPDATE vacparted SET b = 'b';
|
|
|
|
|
VACUUM (ANALYZE) vacparted;
|
|
|
|
|
VACUUM (FULL) vacparted;
|
|
|
|
|
VACUUM (FREEZE) vacparted;
|
2017-09-21 18:13:11 -04:00
|
|
|
|
|
|
|
|
-- check behavior with duplicate column mentions
|
|
|
|
|
VACUUM ANALYZE vacparted(a,b,a);
|
|
|
|
|
ANALYZE vacparted(a,b,b);
|
|
|
|
|
|
2017-03-07 11:24:51 -05:00
|
|
|
DROP TABLE vacparted;
|