|
|
|
@ -42,6 +42,7 @@ static bool rel_is_distinct_for(PlannerInfo *root, RelOptInfo *rel, |
|
|
|
|
List *clause_list); |
|
|
|
|
static Oid distinct_col_search(int colno, List *colnos, List *opids); |
|
|
|
|
static bool is_innerrel_unique_for(PlannerInfo *root, |
|
|
|
|
Relids joinrelids, |
|
|
|
|
Relids outerrelids, |
|
|
|
|
RelOptInfo *innerrel, |
|
|
|
|
JoinType jointype, |
|
|
|
@ -565,7 +566,8 @@ reduce_unique_semijoins(PlannerInfo *root) |
|
|
|
|
innerrel->joininfo); |
|
|
|
|
|
|
|
|
|
/* Test whether the innerrel is unique for those clauses. */ |
|
|
|
|
if (!innerrel_is_unique(root, sjinfo->min_lefthand, innerrel, |
|
|
|
|
if (!innerrel_is_unique(root, |
|
|
|
|
joinrelids, sjinfo->min_lefthand, innerrel, |
|
|
|
|
JOIN_SEMI, restrictlist, true)) |
|
|
|
|
continue; |
|
|
|
|
|
|
|
|
@ -947,7 +949,8 @@ distinct_col_search(int colno, List *colnos, List *opids) |
|
|
|
|
* |
|
|
|
|
* We need an actual RelOptInfo for the innerrel, but it's sufficient to |
|
|
|
|
* identify the outerrel by its Relids. This asymmetry supports use of this |
|
|
|
|
* function before joinrels have been built. |
|
|
|
|
* function before joinrels have been built. (The caller is expected to |
|
|
|
|
* also supply the joinrelids, just to save recalculating that.) |
|
|
|
|
* |
|
|
|
|
* The proof must be made based only on clauses that will be "joinquals" |
|
|
|
|
* rather than "otherquals" at execution. For an inner join there's no |
|
|
|
@ -966,6 +969,7 @@ distinct_col_search(int colno, List *colnos, List *opids) |
|
|
|
|
*/ |
|
|
|
|
bool |
|
|
|
|
innerrel_is_unique(PlannerInfo *root, |
|
|
|
|
Relids joinrelids, |
|
|
|
|
Relids outerrelids, |
|
|
|
|
RelOptInfo *innerrel, |
|
|
|
|
JoinType jointype, |
|
|
|
@ -1014,7 +1018,7 @@ innerrel_is_unique(PlannerInfo *root, |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
/* No cached information, so try to make the proof. */ |
|
|
|
|
if (is_innerrel_unique_for(root, outerrelids, innerrel, |
|
|
|
|
if (is_innerrel_unique_for(root, joinrelids, outerrelids, innerrel, |
|
|
|
|
jointype, restrictlist)) |
|
|
|
|
{ |
|
|
|
|
/*
|
|
|
|
@ -1073,12 +1077,12 @@ innerrel_is_unique(PlannerInfo *root, |
|
|
|
|
*/ |
|
|
|
|
static bool |
|
|
|
|
is_innerrel_unique_for(PlannerInfo *root, |
|
|
|
|
Relids joinrelids, |
|
|
|
|
Relids outerrelids, |
|
|
|
|
RelOptInfo *innerrel, |
|
|
|
|
JoinType jointype, |
|
|
|
|
List *restrictlist) |
|
|
|
|
{ |
|
|
|
|
Relids joinrelids = bms_union(outerrelids, innerrel->relids); |
|
|
|
|
List *clause_list = NIL; |
|
|
|
|
ListCell *lc; |
|
|
|
|
|
|
|
|
|