Re: Complex outer joins?

From: Greg Stark <gsstark(at)mit(dot)edu>
To: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
Cc: "Correia, Carla" <Carla(dot)Correia(at)logicacmg(dot)com>, "'pgsql-sql(at)postgresql(dot)org'" <pgsql-sql(at)postgresql(dot)org>
Subject: Re: Complex outer joins?
Date: 2003-03-26 14:36:11
Message-ID: 87smtakxes.fsf@stark.dyndns.tv
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql

Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> writes:

> The SQL-standard way of writing this would presumably be either
>
> from G left join L on (G.SELID = L.SELID)
> left join C on (L.SELID = C.SELID and L.SELLEVEL = C.SELLEVEL)

I would think of it as this one.

> from G left join
> (L left join C on (L.SELID = C.SELID and L.SELLEVEL = C.SELLEVEL))
> on (G.SELID = L.SELID)

I don't see how that would be at all different.

> depending on which join you think ought to be done first. It might be
> that the results are the same in this case, but I'm not convinced of
> that. In general the results of outer joins definitely depend on join
> order.

I'm pretty sure Oracle actually builds an abstract join representation where
the two queries above would actually be represented the same way. Then decides
the order from amongst the equivalent choices based on performance decisions.

Can you show an example where the join order would affect the result set? I
can't think of any.

--
greg

In response to

Responses

Browse pgsql-sql by date

  From Date Subject
Next Message Stephan Szabo 2003-03-26 15:52:33 Re: Complex outer joins?
Previous Message Tom Lane 2003-03-26 14:06:51 Re: How to show timestamp with milliseconds(3 digits) in Select clause in Ver7.1 ?