pgsql: Fix semijoin unique-ification for child relations

Поиск
Список
Период
Сортировка
От Richard Guo
Тема pgsql: Fix semijoin unique-ification for child relations
Дата
Msg-id E1urqY9-002Alu-1B@gemulon.postgresql.org
обсуждение исходный текст
Список pgsql-committers
Fix semijoin unique-ification for child relations

For a child relation, we should not assume that its parent's
unique-ified relation (or unique-ified path in v18) always exists.  In
cases where all RHS columns that need to be unique-ified are equated
to constants, the unique-ified relation/path for the parent table is
not built, as there are no columns left to unique-ify.  Failing to
account for this can result in a SIGSEGV crash during planning.

This patch checks whether the parent's unique-ified relation or path
exists and skips unique-ification of the child relation if it does
not.

Author: Richard Guo <guofenglinux@gmail.com>
Discussion: https://postgr.es/m/CAMbWs49MOdLW2c+qbLHHBt8VBu=4ONpM91D19=AWeW93eFUF6A@mail.gmail.com
Backpatch-through: 18

Branch
------
REL_18_STABLE

Details
-------
https://git.postgresql.org/pg/commitdiff/58ea074f1433abdd5de792e47ae84c1e56c263f9

Modified Files
--------------
src/backend/optimizer/util/pathnode.c |  9 ++++++
src/test/regress/expected/join.out    | 60 +++++++++++++++++++++++++++++++++++
src/test/regress/sql/join.sql         | 37 +++++++++++++++++++++
3 files changed, 106 insertions(+)


В списке pgsql-committers по дате отправления: