Re: subselect prob in view - Mailing list pgsql-sql

From Stephan Szabo
Subject Re: subselect prob in view
Date
Msg-id 20040622062603.U13933@megazone.bigpanda.com
Whole thread Raw
In response to Re: subselect prob in view  (Gary Stainburn <gary.stainburn@ringways.co.uk>)
List pgsql-sql
On Tue, 22 Jun 2004, Gary Stainburn wrote:

> On Monday 21 Jun 2004 4:11 pm, Gary Stainburn wrote:
> > On Monday 21 Jun 2004 3:19 pm, Tom Lane wrote:
> > > Gary Stainburn <gary.stainburn@ringways.co.uk> writes:
> > > >      from requests r, users u, request_types t,
> > > >           request_states s, dealerships d, departments de, customers c
> > > >           left outer join (select co_r_id, count(co_r_id) from comments
> > > > group by co_r_id) co on
> > > >             co.co_r_id = r.r_id
> > > > psql:goole1.sql:45: ERROR:  Relation "r" does not exist
> > >
> > > I think you have learned some bad habits from MySQL :-(
> > >
> > > PostgreSQL follows the SQL spec and makes JOIN bind more tightly than
> > > comma.  Therefore, in the above the LEFT JOIN is only joining "c" to
> > > "co" and its JOIN ON clause can only reference those two relations.
> > >
> > > You could get the behavior you seem to expect by changing each comma
> > > in the from-list to CROSS JOIN.  Then the JOINs all bind left-to-right
> > > and so "r" will be part of the left argument of the LEFT JOIN.
> > >
> > > Note that if you are using a pre-7.4 release this could have negative
> > > effects on performance --- see the user's guide concerning how explicit
> > > JOIN syntax constrains the planner.
> > >
> > >             regards, tom lane
> >
> > Thanks for this Tom, but I've never used MySQL.
> >
> > I'll look at the docs and have another go.
> >
> In order to simplify things, I'm just concentrating on the view to give me the
> two tallies.  The two selects work seperately, but I'm still getting the
> syntax for the combined quiery wrong.  I'm asuming that the problem's before
> the 'on' clause and not the clause itself (I've also tried using 'using'
> instead but that didn't work either.
>
> goole=# select co.co_r_id, co.count as com_count, cor.count as com_unseen
> goole-#   from
> goole-#   (select co_r_id, count(co_r_id)
> goole(#      from comments group by co_r_id) co,
> goole-#   (select co_r_id, count(co_r_id)
> goole(#      from comments where co_id in
> goole(#      (select distinct co_id
> goole(#         from comments c, co_recipients co
> goole(#         where c.co_id = co.cor_co_id and co.cor_viewed is null)
> goole(#      group by co_r_id) cor on co.co_r_id = cor.co_r_id;

AFAICS, you're not using the join syntax between co and cor at the outer
level.  There's nothing to attach that on clause to.  Either you want that
in a where clause (like in the subselect above it) or you want to use
"inner join" between co and cor.


pgsql-sql by date:

Previous
From: Gary Stainburn
Date:
Subject: Re: subselect prob in view
Next
From: Tom Lane
Date:
Subject: Re: subselect prob in view