From: | "David Johnston" <polobo(at)yahoo(dot)com> |
---|---|
To: | "'Lonni J Friedman'" <netllama(at)gmail(dot)com>, "'pgsql-general'" <pgsql-general(at)postgresql(dot)org> |
Subject: | Re: returning rows from an implicit JOIN where results either exist in both tables OR only one table |
Date: | 2011-12-01 21:57:59 |
Message-ID: | 02a601ccb074$4aef3f70$e0cdbe50$@yahoo.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-general |
-----Original Message-----
From: pgsql-general-owner(at)postgresql(dot)org [mailto:pgsql-general-owner(at)postgresql(dot)org] On Behalf Of Lonni J Friedman
Sent: Thursday, December 01, 2011 4:13 PM
To: pgsql-general
Subject: [GENERAL] returning rows from an implicit JOIN where results either exist in both tables OR only one table
I'm stumbling over how to integrate those two tables with static data into the query. The following query works fine as long as there's at least one row in the 'results' table that corresponds to each row in the pending table (however, it doesn't return anything for rows that only exist in 'pending' yet not yet in 'results'):
-----------------------------------------
Implicit JOINs are ALWAYS INNER JOINs
Since you want to use an OUTER JOIN you must be explicit.
I'm not going to try and figure out specifically what you need but from your quick description (all pending and results where available) you need to do something like
"pending" LEFT OUTER JOIN "results" ON ("pending".active = "results".hostname AND "pending".submittracker = "results".submittracker AND "pending".cl = "results".cl)
Then, for conditions dependent upon the "results" (or NULL-able) relation, you need to make sure you explicitly allow for the missing rows:
( "results".current_status IS NULL OR ( your existing "results" conditions ) )
http://www.postgresql.org/docs/9.0/interactive/queries-table-expressions.html#QUERIES-FROM
From | Date | Subject | |
---|---|---|---|
Next Message | Jay Levitt | 2011-12-01 22:01:08 | psql -1 with multiple files? |
Previous Message | Lonni J Friedman | 2011-12-01 21:12:59 | returning rows from an implicit JOIN where results either exist in both tables OR only one table |