ページの先頭行へ戻る
Enterprise Postgres 17 リリース情報

2.2.6 test_decodingモジュールの動作の変更

非互換

Fujitsu Enterprise Postgres 17では、test_decodingモジュールの動作を変更します。

pg_logical_slot_get_changes()関数にskip_empty_xactsオプションを指定した場合、pg_logical_emit_message()関数でtranscationalをtrueとして出力されたメッセージには、BEGINとCOMMITのメッセージが追加されます。

Fujitsu Enterprise Postgres 16 SP1の場合
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)
Fujitsu Enterprise Postgres 17の場合
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)

対処方法

ありません。