From: | Simon Riggs <simon(at)2ndQuadrant(dot)com> |
---|---|
To: | Heikki Linnakangas <heikki(dot)linnakangas(at)enterprisedb(dot)com> |
Cc: | List pgsql-patches <pgsql-patches(at)postgresql(dot)org> |
Subject: | Re: WIP Join Removal |
Date: | 2008-09-02 12:33:34 |
Message-ID: | 1220358814.4371.406.camel@ebony.2ndQuadrant |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-patches |
On Tue, 2008-09-02 at 14:20 +0300, Heikki Linnakangas wrote:
> Simon Riggs wrote:
> > select a.col2
> > from a left outer join b on a.col1 = b.col1
> > where b.col2 = 1;
> >
> > is logically equivalent to
> >
> > select a.col2
> > from a;
>
> No, it's not:
>
> postgres=# CREATE TABLE a (col1 int4, col2 int4);
> CREATE TABLE
> postgres=# CREATE TABLE b (col1 int4, col2 int4);
> CREATE TABLE
> postgres=# INSERT INTO a VALUES (1,1);
> INSERT 0 1
> postgres=# select a.col2 from a;
> col2
> ------
> 1
> (1 row)
>
> postgres=# select a.col2 from a left outer join b on a.col1 = b.col1
> where b.col2 = 1;
> col2
> ------
> (0 rows)
You raise an interesting and important point that shows an error of
mine. Notice that
select a.col2 from a left outer join b on a.col1 = b.col1
*and* b.col2 = 1;
can be re-written as
select a.col2 from a;
whereas
select a.col2 from a left outer join b on a.col1 = b.col1
where b.col2 = 1;
cannot, as you show.
It seems I wrote my original tests using "and" instead of "where" and
hadn't noticed the distinction. Thanks for helping me catch that error.
I will put back the code that looks for an empty filter condition on the
checkrel. That day was not wasted after all.
--
Simon Riggs www.2ndQuadrant.com
PostgreSQL Training, Services and Support
From | Date | Subject | |
---|---|---|---|
Next Message | Greg Smith | 2008-09-02 12:38:11 | Re: posix advises ... |
Previous Message | Peter Eisentraut | 2008-09-02 11:59:37 | Re: TODO item: Implement Boyer-Moore searching (First time hacker) |