]> granicus.if.org Git - postgresql/commit
Fix no-longer-valid shortcuts in expression_returns_set().
authorTom Lane <tgl@sss.pgh.pa.us>
Wed, 14 Jun 2017 15:10:05 +0000 (11:10 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Wed, 14 Jun 2017 15:10:05 +0000 (11:10 -0400)
commit8e72239e9d961c27f02b242e33fa832c364c7a4b
tree5060415d99b58597c4b1282b3f9226d9be83aec8
parenta571c7f661a7b601aafcb12196d004cdb8b8cb23
Fix no-longer-valid shortcuts in expression_returns_set().

expression_returns_set() used to short-circuit its recursion upon
seeing certain node types, such as DistinctExpr, that it knew the
executor did not support set-valued arguments for.  That was never
inherent, though, just a reflection of laziness in execQual.c.
With the new implementation of SRFs there is no reason to think
that any scalar-valued expression node could not have a set-valued
subexpression, except for AggRefs and WindowFuncs where we know there
is a parser check rejecting it.  And indeed, the shortcut causes
unexpected failures for cases such as a SRF underneath DistinctExpr,
because the planner stops looking for SRFs too soon.

Discussion: https://postgr.es/m/5259.1497044025@sss.pgh.pa.us
src/backend/nodes/nodeFuncs.c
src/test/regress/expected/tsrf.out
src/test/regress/sql/tsrf.sql