]> granicus.if.org Git - postgresql/commit
Fix some planner issues with degenerate outer join clauses.
authorTom Lane <tgl@sss.pgh.pa.us>
Sun, 2 Aug 2015 00:57:41 +0000 (20:57 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Sun, 2 Aug 2015 00:57:41 +0000 (20:57 -0400)
commitb9dfa07e8ebc4b6fded7a64038873e589eebd7df
treee0cb41fe82d70e7247e419859960601dc394e5d5
parentea6e286491210e4ec2ddd542faccfe9227eb890f
Fix some planner issues with degenerate outer join clauses.

An outer join clause that didn't actually reference the RHS (perhaps only
after constant-folding) could confuse the join order enforcement logic,
leading to wrong query results.  Also, nested occurrences of such things
could trigger an Assertion that on reflection seems incorrect.

Per fuzz testing by Andreas Seltenreich.  The practical use of such cases
seems thin enough that it's not too surprising we've not heard field
reports about it.

This has been broken for a long time, so back-patch to all active branches.
src/backend/optimizer/path/joinrels.c
src/backend/optimizer/plan/initsplan.c
src/test/regress/expected/join.out
src/test/regress/sql/join.sql