Re: WIP Join Removal - Mailing list pgsql-patches

From Simon Riggs
Subject Re: WIP Join Removal
Date
Msg-id 1220352898.4371.355.camel@ebony.2ndQuadrant
Whole thread Raw
In response to Re: WIP Join Removal  (Heikki Linnakangas <heikki.linnakangas@enterprisedb.com>)
Responses Re: WIP Join Removal
Re: WIP Join Removal
Re: WIP Join Removal
List pgsql-patches
On Tue, 2008-09-02 at 13:41 +0300, Heikki Linnakangas wrote:
> Simon Riggs wrote:
> > On Tue, 2008-09-02 at 13:20 +0300, Heikki Linnakangas wrote:
> >> Simon Riggs wrote:
> >>> It turns out that a join like this
> >>>
> >>> select a.col2
> >>> from a left outer join b on a.col1 = b.col1
> >>> where b.col2 = 1;
> >>>
> >>> can be cheaper if we don't remove the join, when there is an index on
> >>> a.col1 and b.col2, because the presence of b allows the values returned
> >>> from b to be used for an index scan on a.
> >> Umm, you *can't* remove that join.
> >
> > Yes, you can. The presence or absence of rows in b is not important to
> > the result of the query because of the "left outer join".
> >
> > I spent nearly a whole day going down that deadend also.
>
> Oh. How does the query look like after removing the join, then?

Same answer, just slower. Removing the join makes the access to a into a
SeqScan, whereas it was a two-table index plan when both tables present.
The two table plan is added by the immediately preceding call add_... -
i.e. that plan is only added during join time not during planning of
base relations.

--
 Simon Riggs           www.2ndQuadrant.com
 PostgreSQL Training, Services and Support


pgsql-patches by date:

Previous
From: Heikki Linnakangas
Date:
Subject: Re: WIP Join Removal
Next
From: Heikki Linnakangas
Date:
Subject: Re: WIP Join Removal