aboutsummaryrefslogtreecommitdiff
path: root/.mailmap
diff options
context:
space:
mode:
authorDean Rasheed <dean.a.rasheed@gmail.com>2025-05-31 12:12:58 +0100
committerDean Rasheed <dean.a.rasheed@gmail.com>2025-05-31 12:12:58 +0100
commitb006bcd5310eb2dad0828a286b79babce4953143 (patch)
tree4f05c55faf09167d91ebc5d89a8361c271dc6978 /.mailmap
parente050af28686e796bdf22cb53fe3fdf1c6655f315 (diff)
downloadpostgresql-master.tar.gz
postgresql-master.zip
Fix MERGE into a plain inheritance parent table.HEADmaster
When a MERGE's target table is the parent of an inheritance tree, any INSERT actions insert into the parent table using ModifyTableState's rootResultRelInfo. However, there are two bugs in the way is initialized: 1. ExecInitMerge() incorrectly uses a different ResultRelInfo entry from ModifyTableState's resultRelInfo array to build the insert projection, which may not be compatible with rootResultRelInfo. 2. ExecInitModifyTable() does not fully initialize rootResultRelInfo. Specifically, ri_WithCheckOptions, ri_WithCheckOptionExprs, ri_returningList, and ri_projectReturning are not initialized. This can lead to crashes, or incorrect query results due to failing to check WCO's or process the RETURNING list for INSERT actions. Fix both these bugs in ExecInitMerge(), noting that it is only necessary to fully initialize rootResultRelInfo if the MERGE has INSERT actions and the target table is a plain inheritance parent. Backpatch to v15, where MERGE was introduced. Reported-by: Andres Freund <andres@anarazel.de> Author: Dean Rasheed <dean.a.rasheed@gmail.com> Reviewed-by: Jian He <jian.universality@gmail.com> Reviewed-by: Tender Wang <tndrwang@gmail.com> Discussion: https://postgr.es/m/4rlmjfniiyffp6b3kv4pfy4jw3pciy6mq72rdgnedsnbsx7qe5@j5hlpiwdguvc Backpatch-through: 15
Diffstat (limited to '.mailmap')
0 files changed, 0 insertions, 0 deletions