]> git.ipfire.org Git - thirdparty/postgresql.git/commit
Fix bogus ctid requirement for dummy-root partitioned targets
authorAmit Langote <amitlan@postgresql.org>
Fri, 23 Jan 2026 01:20:51 +0000 (10:20 +0900)
committerAmit Langote <amitlan@postgresql.org>
Fri, 23 Jan 2026 01:23:26 +0000 (10:23 +0900)
commit9f4b7bfc5eb6b3068f35ef5b879d3d8725f5f167
tree3770d23d124c34dc0b9c5e567b68add5803871d5
parent9f7c803c91584fb6e4b45dc87de44bac370477a9
Fix bogus ctid requirement for dummy-root partitioned targets

ExecInitModifyTable() unconditionally required a ctid junk column even
when the target was a partitioned table. This led to spurious "could
not find junk ctid column" errors when all children were excluded and
only the dummy root result relation remained.

A partitioned table only appears in the result relations list when all
leaf partitions have been pruned, leaving the dummy root as the sole
entry. Assert this invariant (nrels == 1) and skip the ctid requirement.
Also adjust ExecModifyTable() to tolerate invalid ri_RowIdAttNo for
partitioned tables, which is safe since no rows will be processed in
this case.

Bug: #19099
Reported-by: Alexander Lakhin <exclusion@gmail.com>
Author: Amit Langote <amitlangote09@gmail.com>
Reviewed-by: Tender Wang <tndrwang@gmail.com>
Reviewed-by: Kirill Reshke <reshkekirill@gmail.com>
Reviewed-by: Tom Lane <tgl@sss.pgh.pa.us>
Discussion: https://postgr.es/m/19099-e05dcfa022fe553d%40postgresql.org
Backpatch-through: 14
contrib/file_fdw/expected/file_fdw.out
contrib/file_fdw/sql/file_fdw.sql
src/backend/executor/nodeModifyTable.c