aboutsummaryrefslogtreecommitdiff
path: root/src/backend/commands/dbcommands.c
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2023-03-28 11:36:50 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2023-03-28 11:39:24 -0400
commit326a33a289c7ba2dbf45f17e610b7be98dc11f67 (patch)
tree165421bbc599565220b1a09cada03f57f62ecf84 /src/backend/commands/dbcommands.c
parentc1f1c1f87fd685981c45da528649c700b6ba0655 (diff)
downloadpostgresql-326a33a289c7ba2dbf45f17e610b7be98dc11f67.tar.gz
postgresql-326a33a289c7ba2dbf45f17e610b7be98dc11f67.zip
Fix corner-case planner failure for MERGE.
MERGE planning could fail with "variable not found in subplan target list" if the target table is partitioned and all its partitions are excluded at plan time, or in the case where it has no partitions but used to have some. This happened because distribute_row_identity_vars thought it didn't need to make the target table's reltarget list fully valid; but if we generate a join plan then that is required because the dummy Result node's tlist will be made from the reltarget. The same logic appears in distribute_row_identity_vars in v14, but AFAICS the problem is unreachable in that branch for lack of MERGE. In other updating statements, the target table is always inner-joined to any other tables, so if the target is known dummy then the whole plan reduces to dummy, so no join nodes are created. So I'll refrain from back-patching this code change to v14 for now. Per report from Alvaro Herrera. Discussion: https://postgr.es/m/20230328112248.6as34mlx5sr4kltg@alvherre.pgsql
Diffstat (limited to 'src/backend/commands/dbcommands.c')
0 files changed, 0 insertions, 0 deletions