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
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 ? |