CREATE TABLE versioning (a bigint, "b b" date, sys_period tstzrange); -- Insert some data before versioning is enabled. INSERT INTO versioning (a, sys_period) VALUES (1, tstzrange('-infinity', NULL)); INSERT INTO versioning (a, sys_period) VALUES (2, tstzrange('2000-01-01', NULL)); CREATE TABLE versioning_history (a bigint, "b b" date, c date, sys_period tstzrange); CREATE TRIGGER versioning_trigger BEFORE INSERT OR UPDATE OR DELETE ON versioning FOR EACH ROW EXECUTE PROCEDURE versioning('sys_period', 'versioning_history', false); -- Insert + Update. BEGIN; INSERT INTO versioning (a) VALUES (3); UPDATE versioning SET a = 4 WHERE a = 3; SELECT a, "b b", lower(sys_period) = CURRENT_TIMESTAMP FROM versioning ORDER BY a, sys_period; a | b b | ?column? ---+-----+---------- 1 | | f 2 | | f 4 | | t (3 rows) SELECT * FROM versioning_history ORDER BY a, sys_period; a | b b | c | sys_period ---+-----+---+------------ (0 rows) COMMIT; -- Make sure that the next transaction's CURRENT_TIMESTAMP is different. SELECT pg_sleep(0.1); pg_sleep ---------- (1 row) -- Multiple updates. BEGIN; UPDATE versioning SET a = 5 WHERE a = 4; UPDATE versioning SET "b b" = '2012-01-01' WHERE a = 5; SELECT a, "b b", lower(sys_period) = CURRENT_TIMESTAMP FROM versioning ORDER BY a, sys_period; a | b b | ?column? ---+------------+---------- 1 | | f 2 | | f 5 | 01-01-2012 | t (3 rows) SELECT a, "b b", c, upper(sys_period) = CURRENT_TIMESTAMP FROM versioning_history ORDER BY a, sys_period; a | b b | c | ?column? ---+-----+---+---------- 4 | | | t (1 row) COMMIT; -- Make sure that the next transaction's CURRENT_TIMESTAMP is different. SELECT pg_sleep(0.1); pg_sleep ---------- (1 row) -- Insert + Delete. BEGIN; INSERT INTO versioning (a) VALUES (6); DELETE FROM versioning WHERE a = 6; SELECT a, "b b", lower(sys_period) = CURRENT_TIMESTAMP FROM versioning ORDER BY a, sys_period; a | b b | ?column? ---+------------+---------- 1 | | f 2 | | f 5 | 01-01-2012 | f (3 rows) SELECT a, "b b", c, upper(sys_period) = CURRENT_TIMESTAMP FROM versioning_history ORDER BY a, sys_period; a | b b | c | ?column? ---+-----+---+---------- 4 | | | f (1 row) END; -- Make sure that the next transaction's CURRENT_TIMESTAMP is different. SELECT pg_sleep(0.1); pg_sleep ---------- (1 row) -- Update + Delete. BEGIN; UPDATE versioning SET "b b" = '2015-01-01' WHERE a = 5; DELETE FROM versioning WHERE a = 5; SELECT a, "b b", lower(sys_period) = CURRENT_TIMESTAMP FROM versioning ORDER BY a, sys_period; a | b b | ?column? ---+-----+---------- 1 | | f 2 | | f (2 rows) SELECT a, "b b", c, upper(sys_period) = CURRENT_TIMESTAMP FROM versioning_history ORDER BY a, sys_period; a | b b | c | ?column? ---+------------+---+---------- 4 | | | f 5 | 01-01-2012 | | t (2 rows) END; DROP TABLE versioning; DROP TABLE versioning_history;