非互換
Fujitsu Enterprise Postgres 17では、test_decodingモジュールの動作を変更します。
pg_logical_slot_get_changes()関数にskip_empty_xactsオプションを指定した場合、pg_logical_emit_message()関数でtranscationalをtrueとして出力されたメッセージには、BEGINとCOMMITのメッセージが追加されます。
postgres=# SELECT 'msg1' FROM pg_logical_emit_message(true, 'test', 'msg1');
?column?
----------
msg1
(1 row)
postgres=# SELECT 'msg2' FROM pg_logical_emit_message(false, 'test', 'msg2');
?column?
----------
msg2
(1 row)
postgres=# SELECT data FROM pg_logical_slot_get_changes('regression_slot', NULL, NULL, 'force-binary', '0', 'skip-empty-xacts', '1', 'include-xids', '0');
data
------------------------------------------------------------
message: transactional: 1 prefix: test, sz: 4 content:msg1
message: transactional: 0 prefix: test, sz: 4 content:msg2
(2 rows)
postgres=# SELECT data FROM pg_logical_slot_get_changes('regression_slot', NULL, NULL, 'force-binary', '0', 'skip-empty-xacts', '1', 'include-xids', '0');
data
------------------------------------------------------------
BEGIN
message: transactional: 1 prefix: test, sz: 4 content:msg1
COMMIT
message: transactional: 0 prefix: test, sz: 4 content:msg2
(4 rows)
対処方法
ありません。