On Sat, Sep 06, 2003 at 14:07:09 +0300, Alexei Chetroi <[EMAIL PROTECTED]> wrote: > Hi All, > > I need a little help regarding writing some subqueries. For example I > have a table "items" which contains columns: itemid, description; and > another table "events" with columns: itemid, date, event. events.itemid > references items.itemid. Table events contains events regarding some > itemid's from table items, so there could be multiple events regarding > one item from items table. for example: > > Table: items > itemid description > 1 Lamp > 2 Desk > 3 HiFi > > Table: events > itemid event date > 1 purchase 2003-01-01 > 1 repair 2003-01-03 > 1 repair 2003-02-05 > 2 purchase 2003-02-01 > 3 HiFi 2003-02-01 > > I'd like to write a query which returns following information regarding > each item: item, date of very first event, very last event. > Is this possible? I think I can write several SELECT queries and > procces them by an application or possibly write some procedure, but > what is better solution?
You can use group by to do this. If there were a large amount of events per item, you might get better performance by using disctinct on and limit in subqueries to get the max and min. That doesn't seem likely for this problem. Distinct on would also be useful if you want to get the event with the first and last dates. The query you want looks something like this: select description, min(date), max(date) from items, events where items.itemid = events.itemid group by description; ---------------------------(end of broadcast)--------------------------- TIP 5: Have you checked our extensive FAQ? http://www.postgresql.org/docs/faqs/FAQ.html