Thread: pgsql: Prevent bogus pullup of constant-valued functions returning comp

pgsql: Prevent bogus pullup of constant-valued functions returning comp

From
Tom Lane
Date:
Prevent bogus pullup of constant-valued functions returning composite.

Fix an oversight in commit 7266d0997: as it stood, the code failed
when a function-in-FROM returns composite and can be simplified
to a composite constant.

For the moment, just test for composite result and abandon pullup
if we see one.  To make it actually work, we'd have to decompose
the composite constant into per-column constants; which is surely
do-able, but I'm not convinced it's worth the code space.

Per report from Raúl Marín Rodríguez.

Discussion: https://postgr.es/m/CAM6_UM4isP+buRA5sWodO_MUEgutms-KDfnkwGmryc5DGj9XuQ@mail.gmail.com

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/a9ae99d0190960ce2d3dd3e5f10e7f4adc3cf203

Modified Files
--------------
src/backend/optimizer/prep/prepjointree.c | 18 +++++++++++++++
src/test/regress/expected/join.out        | 37 +++++++++++++++++++++++++++++++
src/test/regress/sql/join.sql             | 19 ++++++++++++++++
3 files changed, 74 insertions(+)