pgsql: Fix concurrent update issue with MERGE. - Mailing list pgsql-committers

From Dean Rasheed
Subject pgsql: Fix concurrent update issue with MERGE.
Date
Msg-id E1uuQsl-000aid-1R@gemulon.postgresql.org
Whole thread Raw
List pgsql-committers
Fix concurrent update issue with MERGE.

When executing a MERGE UPDATE action, if there is more than one
concurrent update of the target row, the lock-and-retry code would
sometimes incorrectly identify the latest version of the target tuple,
leading to incorrect results.

This was caused by using the ctid field from the TM_FailureData
returned by table_tuple_lock() in a case where the result was TM_Ok,
which is unsafe because the TM_FailureData struct is not guaranteed to
be fully populated in that case. Instead, it should use the tupleid
passed to (and updated by) table_tuple_lock().

To reduce the chances of similar errors in the future, improve the
commentary for table_tuple_lock() and TM_FailureData to make it
clearer that table_tuple_lock() updates the tid passed to it, and most
fields of TM_FailureData should not be relied on in non-failure cases.
An exception to this is the "traversed" field, which is set in both
success and failure cases.

Reported-by: Dmitry <dsy.075@yandex.ru>
Author: Yugo Nagata <nagata@sraoss.co.jp>
Reviewed-by: Dean Rasheed <dean.a.rasheed@gmail.com>
Reviewed-by: Chao Li <li.evan.chao@gmail.com>
Discussion: https://postgr.es/m/1570d30e-2b95-4239-b9c3-f7bf2f2f8556@yandex.ru
Backpatch-through: 15

Branch
------
REL_18_STABLE

Details
-------
https://git.postgresql.org/pg/commitdiff/c70b6db34ffeab48beef1fb4ce61bcad3772b8dd

Modified Files
--------------
src/backend/executor/nodeModifyTable.c             |   9 +-
src/include/access/tableam.h                       |  15 ++-
.../isolation/expected/merge-match-recheck.out     | 145 +++++++++++++++++++++
src/test/isolation/specs/merge-match-recheck.spec  |  18 +++
4 files changed, 179 insertions(+), 8 deletions(-)


pgsql-committers by date:

Previous
From: Michael Paquier
Date:
Subject: pgsql: Fix outdated comments in slru.c
Next
From: Melanie Plageman
Date:
Subject: pgsql: Add assert and log message to visibilitymap_set