Thread: pgsql: Fix misuse of RelOptInfo.unique_for_rels cache by SJE

pgsql: Fix misuse of RelOptInfo.unique_for_rels cache by SJE

From
Alexander Korotkov
Date:
Fix misuse of RelOptInfo.unique_for_rels cache by SJE

When SJE uses RelOptInfo.unique_for_rels cache, it passes filtered quals to
innerrel_is_unique_ext().  That might lead to an invalid match to cache entries
made by previous non self-join checking calls.  Add UniqueRelInfo.self_join
flag to prevent such cases.  Also, fix that SJE should require a strict match
of outerrelids to make sure UniqueRelInfo.extra_clauses are valid.

Reported-by: Alexander Lakhin
Discussion: https://postgr.es/m/4788f781-31bd-9796-d7d6-588a751c8787%40gmail.com

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/30b4955a4668887044568743debef804b14418ca

Modified Files
--------------
src/backend/optimizer/plan/analyzejoins.c | 30 +++++++++++++++++++++---------
src/include/nodes/pathnodes.h             |  6 ++++++
src/test/regress/expected/join.out        | 23 +++++++++++++++++++++++
src/test/regress/sql/join.sql             |  9 +++++++++
4 files changed, 59 insertions(+), 9 deletions(-)