非互換
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)
対処方法
ありません。