Re: double left outer join on the same table

From: T E Schmitz <mailreg(at)numerixtechnology(dot)de>
To: Adam Witney <awitney(at)sghms(dot)ac(dot)uk>
Cc: pgsql-sql <pgsql-sql(at)postgresql(dot)org>
Subject: Re: double left outer join on the same table
Date: 2004-05-02 17:09:30
Message-ID: 40952B4A.6090300@numerixtechnology.de
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql

Hi Adam, this is absolute magic getting a reply within 1/2 hour and a
working solution at that!

Here's the correct syntax :

SELECT
SECTION.SECTION_PK,
SECTION.SECTION_NAME,
SECTION.BRAND_1_FK,
SECTION.BRAND_2_FK,
b1.BRAND_NAME,
b2.BRAND_NAME

FROM SECTION
left outer join BRAND as b1 on b1.BRAND_PK =BRAND_1_FK
left outer join BRAND as b2 on b2.BRAND_PK =BRAND_2_FK

Kind Regards,

Tarlika Elisabeth Schmitz

Adam Witney wrote:
> On 2/5/04 5:23 pm, "T E Schmitz" <mailreg(at)numerixtechnology(dot)de> wrote:
>
>
>>Hello,
>>
>>I have two tables SECTION and BRAND. SECTION is related to BRAND via two
>>foreign keys. I would like to select ALL SECTIONs whether the FKs are
>>null or not and fetch the BRAND attributes in one SQL statement. In
>>other words I need a double outer join.
>>
>>Is this possible at all?
>>
>>The following doesn't work for two reasons:
>>a) Table name "brand" specified more than once.
>>b) how would I specify the same output columns twice?
>>
>>SELECT
>>SECTION.SECTION_PK,
>>SECTION.SECTION_NAME,
>>SECTION.BRAND_1_FK,
>>SECTION.BRAND_2_FK,
>>BRAND.BRAND_PK,
>>BRAND.BRAND_NAME
>>
>>FROM SECTION
>>left outer join BRAND on BRAND_PK =BRAND_1_FK
>>left outer join BRAND on BRAND_PK =BRAND_2_FK
>>
>
>
> I don't know if this will solve your specific problem, but you can use the
> same table twice in the same query by using aliases, something like this
> (untested of course)
>
> SELECT
> SECTION.SECTION_PK,
> SECTION.SECTION_NAME,
> SECTION.BRAND_1_FK,
> SECTION.BRAND_2_FK,
> a.BRAND_PK,
> a.BRAND_NAME
> b.BRAND_PK,
> b.BRAND_NAME
>
> FROM SECTION
> left outer join BRAND a on BRAND_PK =BRAND_1_FK
> left outer join BRAND b on BRAND_PK =BRAND_2_FK
>
>
>
>

In response to

Browse pgsql-sql by date

  From Date Subject
Next Message jwang 2004-05-03 10:55:23 an indexing problem on postgreSQL
Previous Message Adam Witney 2004-05-02 16:44:36 Re: double left outer join on the same table