From: | Michael Fuhr <mike(at)fuhr(dot)org> |
---|---|
To: | Michael Avila <Michael(dot)Avila(dot)1(at)sbcglobal(dot)net> |
Cc: | SQL PostgreSQL MailList <pgsql-sql(at)postgresql(dot)org> |
Subject: | Re: Need SQL Help Finding Current Status of members |
Date: | 2005-12-18 00:26:10 |
Message-ID: | 20051218002610.GA4832@winnie.fuhr.org |
Views: | Whole Thread | Raw Message | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
On Fri, Dec 16, 2005 at 07:44:46PM -0500, Michael Avila wrote:
> Just tried it and it returned nothing.
>
> > > Select * from memberstatus A where not exists
> > > (select * from emberstatus B where B.member_id=A.member_id and
> > > B.status_date >A.status_date)
>
> Why the WHERE NOT EXISTS?
The query selects each row in memberstatus for which no other rows
(WHERE NOT EXISTS) with the same member_id have a later status_date;
in other words, the row(s) with the latest status_date for each
member_id. For example, given
member_id | status_code | status_date
-----------+-------------+-------------
1 | a | 2005-12-01
1 | b | 2005-12-02
1 | c | 2005-12-03
2 | x | 2005-12-11
2 | y | 2005-12-12
2 | z | 2005-12-13
the query should return
member_id | status_code | status_date
-----------+-------------+-------------
1 | c | 2005-12-03
2 | z | 2005-12-13
Offhand I can't think of why the query would return nothing unless
the table is empty, but maybe I'm overlooking something or making
unwarranted assumptions about the data. Can you post a sample data
set for which the query returns no rows?
--
Michael Fuhr
From | Date | Subject | |
---|---|---|---|
Next Message | Michael Avila | 2005-12-18 00:34:22 | Re: Need SQL Help Finding Current Status of members |
Previous Message | Bruno Wolff III | 2005-12-17 21:35:35 | Re: Help on function creating |