aboutsummaryrefslogtreecommitdiff
path: root/src/backend/optimizer/plan/createplan.c
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2007-07-31 19:54:27 +0000
committerTom Lane <tgl@sss.pgh.pa.us>2007-07-31 19:54:27 +0000
commitc14066aa7049bac14cadc18d0c48bcf6ea81ff52 (patch)
treee1643d93294f4b79c71b10c54c3eae79f8280b59 /src/backend/optimizer/plan/createplan.c
parentfab6a867fd38cb4abe326a9cb68f924d093f3dcf (diff)
downloadpostgresql-c14066aa7049bac14cadc18d0c48bcf6ea81ff52.tar.gz
postgresql-c14066aa7049bac14cadc18d0c48bcf6ea81ff52.zip
Fix a bug in the original implementation of redundant-join-clause removal:
clauses in which one side or the other references both sides of the join cannot be removed as redundant, because that expression won't have been constrained below the join. Per report from Sergey Burladyan.
Diffstat (limited to 'src/backend/optimizer/plan/createplan.c')
-rw-r--r--src/backend/optimizer/plan/createplan.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/backend/optimizer/plan/createplan.c b/src/backend/optimizer/plan/createplan.c
index bbbc013fff5..a28d195e412 100644
--- a/src/backend/optimizer/plan/createplan.c
+++ b/src/backend/optimizer/plan/createplan.c
@@ -10,7 +10,7 @@
*
*
* IDENTIFICATION
- * $Header: /cvsroot/pgsql/src/backend/optimizer/plan/createplan.c,v 1.157.2.3 2004/02/29 17:36:48 tgl Exp $
+ * $Header: /cvsroot/pgsql/src/backend/optimizer/plan/createplan.c,v 1.157.2.4 2007/07/31 19:54:26 tgl Exp $
*
*-------------------------------------------------------------------------
*/
@@ -927,6 +927,8 @@ create_nestloop_plan(Query *root,
select_nonredundant_join_clauses(root,
joinrestrictclauses,
lfirst(indexjoinclauses),
+ best_path->outerjoinpath->parent->relids,
+ best_path->innerjoinpath->parent->relids,
best_path->jointype);
}
}