Re: SQL Query question

Поиск
Список
Период
Сортировка
От Richard Huxton
Тема Re: SQL Query question
Дата
Msg-id 42C3D5E9.8010007@archonet.com
обсуждение исходный текст
Ответ на SQL Query question  ("Nick Stone" <nick@harelane.com>)
Ответы Re: SQL Query question
Список pgsql-sql
Nick Stone wrote:
> Hi
> 
> Whilst I'm not new to SQL I am reasonably new to Postgres and as such I have
> a question on the following query:

> FROM
>     "Terms" As tbl1 LEFT JOIN
>     "SearchStore" As tbl2 ON tbl1."KeywordID" = tbl2."KeywordID" AND
> tbl2."StockID" = 1
> Why does the above query work fine and the folowing query not work? And as a
> additional kind of spanner in the works I've tried the following on MS SQL
> Server and Oracle both of which produce the correct results

> FROM
>     "Terms" As tbl1 LEFT JOIN
>     "SearchStore" As tbl2 ON tbl1."KeywordID" = tbl2."KeywordID"
> WHERE 
...
>     (tbl2."StockID" = 1)

Hmm - I'm not sure that MSSQL/Oracle are giving the "right" answer here. 
I assume the tbl2.stockid test is the issue here, and we apply the test 
after the join whereas the others push the condition inside the join.

I'm inclined to prefer PG's way of doing things, since it means you get 
what you explicitly asked for (to my point of view anyway). Not sure 
what the SQL spec says though, and in the end I suppose that's the only 
way to decide "right".

--  Richard Huxton  Archonet Ltd


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

Предыдущее
От: Peter Eisentraut
Дата:
Сообщение: Re: SQL Query question
Следующее
От: Daryl Richter
Дата:
Сообщение: Re: ORDER records based on parameters in IN clause