Обсуждение: pgsql: Prevent bogus pullup of constant-valued functions returning comp

Поиск
Список
Период
Сортировка

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

От
Tom Lane
Дата:
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(+)