Fix incorrect logic for caching ResultRelInfos for triggers
authorDavid Rowley <[email protected]>
Sat, 25 Oct 2025 22:01:53 +0000 (11:01 +1300)
committerDavid Rowley <[email protected]>
Sat, 25 Oct 2025 22:01:53 +0000 (11:01 +1300)
commit0d307461538082880151c804e037ab3bd85936e7
tree636a9f1d02f2ffb25e257ef24335c5380f0cb3eb
parent256698d26746644e2f688bf3495bd6c55a7d58be
Fix incorrect logic for caching ResultRelInfos for triggers

When dealing with ResultRelInfos for partitions, there are cases where
there are mixed requirements for the ri_RootResultRelInfo.  There are
cases when the partition itself requires a NULL ri_RootResultRelInfo and
in the same query, the same partition may require a ResultRelInfo with
its parent set in ri_RootResultRelInfo.  This could cause the column
mapping between the partitioned table and the partition not to be done
which could result in crashes if the column attnums didn't match
exactly.

The fix is simple.  We now check that the ri_RootResultRelInfo matches
what the caller passed to ExecGetTriggerResultRel() and only return a
cached ResultRelInfo when the ri_RootResultRelInfo matches what the
caller wants, otherwise we'll make a new one.

Author: David Rowley <[email protected]>
Author: Amit Langote <[email protected]>
Reported-by: Dmitry Fomin <[email protected]>
Discussion: https://postgr.es/m/7DCE78D7-0520-4207-822B-92F60AEA14B4@gmail.com
Backpatch-through: 15
src/backend/executor/execMain.c
src/test/regress/expected/foreign_key.out
src/test/regress/sql/foreign_key.sql