Re: where clause on a left outer join

Поиск
Список
Период
Сортировка
От Stephan Szabo
Тема Re: where clause on a left outer join
Дата
Msg-id 20040926171842.A46859@megazone.bigpanda.com
обсуждение исходный текст
Ответ на where clause on a left outer join  (Cris Carampa <cris119@operamail.com>)
Список pgsql-sql
On Wed, 22 Sep 2004, Cris Carampa wrote:

> Hello, let's suppose I have the following tables:
>
> create table parent (
>    parent_id numeric primary key,
>    parent_data text
> ) ;
>
> create table stuff (
>    stuff_id numeric primary key,
>    parent_id numeric references parent,
>    stuff_data text
> ) ;
>
> And the following data:
>
> crisdb=> select * from parent;
>   parent_id | parent_data
> -----------+-------------
>           1 | aaa
>           2 | bbb
>           3 | ccc
> (3 rows)
>
> crisdb=> select * from stuff;
>   stuff_id | parent_id | staff_data
> ----------+-----------+------------
>          1 |         1 | xxx
>          2 |         1 | yyy
>          3 |         1 | zzz
> (3 rows)
>
> I wish to write a query that returns all rows from "parent" and, beside
> of them, staff data with stuff_id=1 if available, otherwise null.
>
> The following query:
>
> select
>    par.parent_id,
>    stu.stuff_data
> from
>    parent par left outer join stuff stu
>    on (
>      par.parent_id = stu.parent_id
>    )
> where
>    stu.stuff_id = 1
> ;

I thinkon (par.parent_id = stu.parent_id and stu.stuff_id=1)
will give the join you want.


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

Предыдущее
От: birdy edwards
Дата:
Сообщение: [ocpfree] Info Needed about OCA
Следующее
От: Stephan Szabo
Дата:
Сообщение: Re: Problem with functions