summaryrefslogtreecommitdiff
path: root/src/backend/replication/pgoutput
diff options
context:
space:
mode:
authorDean Rasheed2025-07-18 08:55:43 +0000
committerDean Rasheed2025-07-18 08:55:43 +0000
commit5022ff250eeba2367fb4e74fed8ee65bcddb6c99 (patch)
treec4ddf28e6f06640981ef2f6df1c209358888b23c /src/backend/replication/pgoutput
parent62c3b4cd9ddc6d3066e3f6e43b68fd00c620d9ad (diff)
Fix concurrent update trigger issues with MERGE in a CTE.HEADmaster
If a MERGE inside a CTE attempts an UPDATE or DELETE on a table with BEFORE ROW triggers, and a concurrent UPDATE or DELETE happens, the merge code would fail (crashing in the case of an UPDATE action, and potentially executing the wrong action for a DELETE action). This is the same issue that 9321c79c86 attempted to fix, except now for a MERGE inside a CTE. As noted in 9321c79c86, what needs to happen is for the trigger code to exit early, returning the TM_Result and TM_FailureData information to the merge code, if a concurrent modification is detected, rather than attempting to do an EPQ recheck. The merge code will then do its own rechecking, and rescan the action list, potentially executing a different action in light of the concurrent update. In particular, the trigger code must never call ExecGetUpdateNewTuple() for MERGE, since that is bound to fail because MERGE has its own per-action projection information. Commit 9321c79c86 did this using estate->es_plannedstmt->commandType in the trigger code to detect that a MERGE was being executed, which is fine for a plain MERGE command, but does not work for a MERGE inside a CTE. Fix by passing that information to the trigger code as an additional parameter passed to ExecBRUpdateTriggers() and ExecBRDeleteTriggers(). Back-patch as far as v17 only, since MERGE cannot appear inside a CTE prior to that. Additionally, take care to preserve the trigger ABI in v17 (though not in v18, which is still in beta). Bug: #18986 Reported-by: Yaroslav Syrytsia <me@ys.lc> Author: Dean Rasheed <dean.a.rasheed@gmail.com> Reviewed-by: Michael Paquier <michael@paquier.xyz> Discussion: https://postgr.es/m/18986-e7a8aac3d339fa47@postgresql.org Backpatch-through: 17
Diffstat (limited to 'src/backend/replication/pgoutput')
0 files changed, 0 insertions, 0 deletions