]> granicus.if.org Git - postgresql/commit
Set scan direction appropriately for SubPlans (bug #15336)
authorAndrew Gierth <rhodiumtoad@postgresql.org>
Fri, 17 Aug 2018 14:04:26 +0000 (15:04 +0100)
committerAndrew Gierth <rhodiumtoad@postgresql.org>
Fri, 17 Aug 2018 14:44:13 +0000 (15:44 +0100)
commit520acab171244b55d816c70b9a89280b09937925
treedac7bf56134f0ad39af47f49a968c7d85c29599c
parent9bed827b18cc4f27fb7cd7c02ad301519eca6d29
Set scan direction appropriately for SubPlans (bug #15336)

When executing a SubPlan in an expression, the EState's direction
field was left alone, resulting in an attempt to execute the subplan
backwards if it was encountered during a backwards scan of a cursor.
Also, though much less likely, it was possible to reach the execution
of an InitPlan while in backwards-scan state.

Repair by saving/restoring estate->es_direction and forcing forward
scan mode in the relevant places.

Backpatch all the way, since this has been broken since 8.3 (prior to
commit c7ff7663e, SubPlans had their own EStates rather than sharing
the parent plan's, so there was no confusion over scan direction).

Per bug #15336 reported by Vladimir Baranoff; analysis and patch by
me, review by Tom Lane.

Discussion: https://postgr.es/m/153449812167.1304.1741624125628126322@wrigleys.postgresql.org
src/backend/executor/nodeSubplan.c
src/test/regress/expected/subselect.out
src/test/regress/sql/subselect.sql