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 84 85 86 87 88 89 90 91 92 93 94
|
\set VERBOSITY terse
-- predictability
SET synchronous_commit = on;
SET extra_float_digits = 0;
DROP TABLE IF EXISTS table_with_pk;
DROP TABLE IF EXISTS table_without_pk;
DROP TABLE IF EXISTS table_with_unique;
CREATE TABLE table_with_pk (
a smallserial,
b smallint,
c int,
d bigint,
e numeric(5,3),
f real not null,
g double precision,
h char(10),
i varchar(30),
j text,
k bit varying(20),
l timestamp,
m date,
n boolean not null,
o json,
p tsvector,
PRIMARY KEY(b, c, d)
);
CREATE TABLE table_without_pk (
a smallserial,
b smallint,
c int,
d bigint,
e numeric(5,3),
f real not null,
g double precision,
h char(10),
i varchar(30),
j text,
k bit varying(20),
l timestamp,
m date,
n boolean not null,
o json,
p tsvector
);
CREATE TABLE table_with_unique (
a smallserial,
b smallint,
c int,
d bigint,
e numeric(5,3) not null,
f real not null,
g double precision not null,
h char(10),
i varchar(30),
j text,
k bit varying(20),
l timestamp,
m date,
n boolean not null,
o json,
p tsvector,
UNIQUE(g, n)
);
-- INSERT
INSERT INTO table_with_pk (b, c, d, e, f, g, h, i, j, k, l, m, n, o, p) VALUES(1, 2, 3, 3.54, 876.563452345, 1.23, 'teste', 'testando', 'um texto longo', B'001110010101010', '2013-11-02 17:30:52', '2013-02-04', true, '{ "a": 123 }', 'Old Old Parr'::tsvector);
INSERT INTO table_with_pk (b, c, d, e, f, g, h, i, j, k, l, m, n, o, p) VALUES(4, 5, 6, 3.54, 876.563452345, 1.23, 'teste', 'testando', 'um texto longo', B'001110010101010', '2013-11-02 17:30:52', '2013-02-04', true, '{ "a": 123 }', 'Old Old Parr'::tsvector);
INSERT INTO table_without_pk (b, c, d, e, f, g, h, i, j, k, l, m, n, o, p) VALUES(1, 2, 3, 3.54, 876.563452345, 1.23, 'teste', 'testando', 'um texto longo', B'001110010101010', '2013-11-02 17:30:52', '2013-02-04', true, '{ "a": 123 }', 'Old Old Parr'::tsvector);
INSERT INTO table_with_unique (b, c, d, e, f, g, h, i, j, k, l, m, n, o, p) VALUES(1, 2, 3, 3.54, 876.563452345, 1.23, 'teste', 'testando', 'um texto longo', B'001110010101010', '2013-11-02 17:30:52', '2013-02-04', true, '{ "a": 123 }', 'Old Old Parr'::tsvector);
SELECT 'init' FROM pg_create_logical_replication_slot('regression_slot', 'wal2json');
-- DELETE: REPLICA IDENTITY FULL
ALTER TABLE table_with_pk REPLICA IDENTITY FULL;
DELETE FROM table_with_pk WHERE b = 1;
DELETE FROM table_with_pk WHERE n = true;
ALTER TABLE table_with_pk REPLICA IDENTITY DEFAULT;
ALTER TABLE table_without_pk REPLICA IDENTITY FULL;
DELETE FROM table_without_pk WHERE b = 1;
ALTER TABLE table_without_pk REPLICA IDENTITY DEFAULT;
ALTER TABLE table_with_unique REPLICA IDENTITY FULL;
DELETE FROM table_with_unique WHERE b = 1;
ALTER TABLE table_with_unique REPLICA IDENTITY DEFAULT;
SELECT data FROM pg_logical_slot_peek_changes('regression_slot', NULL, NULL, 'format-version', '1', 'pretty-print', '1', 'include-typmod', '0');
SELECT data FROM pg_logical_slot_peek_changes('regression_slot', NULL, NULL, 'format-version', '2');
SELECT 'stop' FROM pg_drop_replication_slot('regression_slot');
|