]> git.ipfire.org Git - thirdparty/postgresql.git/commit
Fix semijoin unique-ification for child relations
authorRichard Guo <rguo@postgresql.org>
Fri, 29 Aug 2025 04:14:12 +0000 (13:14 +0900)
committerRichard Guo <rguo@postgresql.org>
Fri, 29 Aug 2025 04:14:12 +0000 (13:14 +0900)
commit97b0f36bde9a08bc6f004438ff8fc0afbcb418c0
tree207c4d4099365a00108bb7f35c5ba99c4be7868f
parentfabd8b8e2a72bac9e5a361856a355bd5bb2e61b8
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
src/backend/optimizer/plan/planner.c
src/test/regress/expected/join.out
src/test/regress/sql/join.sql