summaryrefslogtreecommitdiff
path: root/doc/src/sgml/ref/set_constraints.sgml
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2024-01-11 15:28:13 -0500
committerTom Lane <tgl@sss.pgh.pa.us>2024-01-11 15:28:13 -0500
commitbfd28bb07a1fd83f42c6a37ccfc33b1e4959db52 (patch)
tree0ff7a1c9bb468ff8caea71bfa450b270ffc1696b /doc/src/sgml/ref/set_constraints.sgml
parent9a94e9ae7ea2f0aced00a53ab618ee4f7c46cc5e (diff)
Allow subquery pullup to wrap a PlaceHolderVar in another one.
The code for wrapping subquery output expressions in PlaceHolderVars believed that if the expression already was a PlaceHolderVar, it was never necessary to wrap that in another one. That's wrong if the expression is underneath an outer join and involves a lateral reference to outside that scope: failing to add an additional PHV risks evaluating the expression at the wrong place and hence not forcing it to null when the outer join should do so. This is an oversight in commit 9e7e29c75, which added logic to forcibly wrap lateral-reference Vars in PlaceHolderVars, but didn't see that the adjacent case for PlaceHolderVars needed the same treatment. The test case we have for this doesn't fail before 4be058fe9, but now that I see the problem I wonder if it is possible to demonstrate related errors before that. That's moot though, since all such branches are out of support. Per bug #18284 from Holger Reise. Back-patch to all supported branches. Discussion: https://postgr.es/m/18284-47505a20c23647f8@postgresql.org
Diffstat (limited to 'doc/src/sgml/ref/set_constraints.sgml')
0 files changed, 0 insertions, 0 deletions