mirror of
https://github.com/postgres/postgres.git
synced 2025-06-11 20:28:21 +03:00
Introduce xid8-based functions to replace txid_XXX.
The txid_XXX family of fmgr functions exposes 64 bit transaction IDs to users as int8. Now that we have an SQL type xid8 for FullTransactionId, define a new set of functions including pg_current_xact_id() and pg_current_snapshot() based on that. Keep the old functions around too, for now. It's a bit sneaky to use the same C functions for both, but since the binary representation is identical except for the signedness of the type, and since older functions are the ones using the wrong signedness, and since we'll presumably drop the older ones after a reasonable period of time, it seems reasonable to switch to FullTransactionId internally and share the code for both. Reviewed-by: Fujii Masao <masao.fujii@oss.nttdata.com> Reviewed-by: Takao Fujii <btfujiitkp@oss.nttdata.com> Reviewed-by: Yoshikazu Imai <imai.yoshikazu@fujitsu.com> Reviewed-by: Mark Dilger <mark.dilger@enterprisedb.com> Discussion: https://postgr.es/m/20190725000636.666m5mad25wfbrri%40alap3.anarazel.de
This commit is contained in:
@ -220,7 +220,7 @@ SELECT data FROM pg_logical_slot_get_changes('regression_slot', NULL, NULL, 'inc
|
||||
-- test whether a known, but not yet logged toplevel xact, followed by a
|
||||
-- subxact commit is handled correctly
|
||||
BEGIN;
|
||||
SELECT txid_current() != 0; -- so no fixed xid apears in the outfile
|
||||
SELECT pg_current_xact_id() != '0'; -- so no fixed xid apears in the outfile
|
||||
SAVEPOINT a;
|
||||
INSERT INTO tr_sub(path) VALUES ('4-top-1-#1');
|
||||
RELEASE SAVEPOINT a;
|
||||
|
@ -3,13 +3,13 @@ SET synchronous_commit = on;
|
||||
|
||||
-- fail because we're creating a slot while in an xact with xid
|
||||
BEGIN;
|
||||
SELECT txid_current() = 0;
|
||||
SELECT pg_current_xact_id() = '0';
|
||||
SELECT 'init' FROM pg_create_logical_replication_slot('regression_slot', 'test_decoding');
|
||||
ROLLBACK;
|
||||
|
||||
-- fail because we're creating a slot while in a subxact whose topxact has an xid
|
||||
BEGIN;
|
||||
SELECT txid_current() = 0;
|
||||
SELECT pg_current_xact_id() = '0';
|
||||
SAVEPOINT barf;
|
||||
SELECT 'init' FROM pg_create_logical_replication_slot('regression_slot', 'test_decoding');
|
||||
ROLLBACK TO SAVEPOINT barf;
|
||||
@ -29,7 +29,7 @@ INSERT INTO nobarf(data) VALUES('1');
|
||||
|
||||
-- decoding works in transaction with xid
|
||||
BEGIN;
|
||||
SELECT txid_current() = 0;
|
||||
SELECT pg_current_xact_id() = '0';
|
||||
-- don't show yet, haven't committed
|
||||
INSERT INTO nobarf(data) VALUES('2');
|
||||
SELECT data FROM pg_logical_slot_get_changes('regression_slot', NULL, NULL, 'include-xids', '0', 'skip-empty-xacts', '1');
|
||||
|
Reference in New Issue
Block a user