Re: Complex outer joins?

Поиск
Список
Период
Сортировка
От Greg Stark
Тема Re: Complex outer joins?
Дата
Msg-id 87smtakxes.fsf@stark.dyndns.tv
обсуждение исходный текст
Ответ на Re: Complex outer joins?  (Tom Lane <tgl@sss.pgh.pa.us>)
Ответы Re: Complex outer joins?  (Stephan Szabo <sszabo@megazone23.bigpanda.com>)
Список pgsql-sql
Tom Lane <tgl@sss.pgh.pa.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



В списке pgsql-sql по дате отправления:

Предыдущее
От: Tom Lane
Дата:
Сообщение: Re: How to show timestamp with milliseconds(3 digits) in Select clause in Ver7.1 ?
Следующее
От: Stephan Szabo
Дата:
Сообщение: Re: Complex outer joins?