From: | Tomasz Myrta <jasiek(at)klaster(dot)net> |
---|---|
To: | Gary Stainburn <gary(dot)stainburn(at)ringways(dot)co(dot)uk> |
Cc: | pgsql-sql(at)postgresql(dot)org |
Subject: | Re: efficient count/join query |
Date: | 2003-02-07 10:48:47 |
Message-ID: | 3E438F0F.5000301@klaster.net |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
Gary Stainburn wrote:
> Hi folks,
>
> I've got two tables, first a history table containing tallies for staff/jobs
> prior to going live, and second a roster table showing date, diagram, job
> with one record per person per job per day. the tables are:
>
> create table history (
> hsid int4 not null references staff(sid),
> hjid int4 not null references jobs(jid),
> hcount int4,
> primary key (hsid,hjid));
>
> create table roster (
> rodate date not null,
> rogid int4 not null references diagrams(gid),
> rojid int4 not null references jobs(jid),
> rosid int4 references staff(sid),
> primary key (rodate, rogid, rojid));
>
> What's the best/quickest/cheapest way to create a view in the format of the
> history table but including the details from the roster table for all records
> prior to today.
>
> I've been looking at some form of sub-select/join scheme but as some will only
> exist on the history and some will only exist on the roster while many will
> exist on both.
Hello again.
What if they exists in both tables - you need only one row result?
If yes, you should use FULL OUTER JOIN and COALESCE.
select
coalesce(hjid,rjid) as jid,
coalesce(hsid,rsid) as sid,
hcount,
rodate,
rogid
from
history
full outer join roster on (hjid=rjid and hsid=rosid)
Using other names for the same field in other tables comes again -
If you have the same name for jid and sid, you wouldn't need coalesce.
Regards,
Tomasz Myrta
From | Date | Subject | |
---|---|---|---|
Next Message | Christoph Haller | 2003-02-07 11:39:04 | Re: Lock timeout detection in postgres 7.3.1 |
Previous Message | Tomasz Myrta | 2003-02-07 10:31:46 | Re: SET TIMEOUT equivalent / was: Lock timeout detection |