From: | Leo Mannhart <leo(dot)mannhart(at)beecom(dot)ch> |
---|---|
To: | John <jfabiani(at)yolo(dot)com> |
Cc: | "pgsql-sql(at)postgresql(dot)org" <pgsql-sql(at)postgresql(dot)org> |
Subject: | Re: two records per row from query |
Date: | 2009-08-06 13:42:34 |
Message-ID: | 4A7ADDCA.2060809@beecom.ch |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
John wrote:
> mytable
> pkid
> class_date.
> sessionid
>
> select * from mytable
> 1 2009/01/01 2101
> 2 2009/01/02 2101
>
> I would like an SQL that would produce
>
> newtable
> pkid,
> class_date1,
> class_date2,
> sessionid1,
> sessionid2
>
> Select * from newtable
>
> 1 2009/01/01 2009/01/02 2101 2101
>
> I have a list of classes that is perfect for our needs. However, I need to
> create the second table (from a query) to feed to a report writer so it can
> write out a single line of text for two records.
> Like:
>
> Your class dates are as follows
>
> Date Date
> 01/01/2009 01/02/2009
> 01/08/2009 01/10/2009
> 03/31/2009 04/05/2009
> and will continue until the all the classes are printed.
>
> The problem of course is the table has a row per class and the report writer
> needs two class dates per row.
>
> I have no idea how to do this using SQL.
>
> Thanks in advance,
> Johnf
>
Can you give a more precise example please? I don't get what you really
need. What I understand is that you want 1 record back for each
sessionid with the earliest and latest class_date.
I've done the following:
lem=# select * from mytable;
pkid | class_date | sessionid
------+---------------------+-----------
1 | 2009-01-01 00:00:00 | 2101
2 | 2009-01-02 00:00:00 | 2101
3 | 2009-01-01 00:00:00 | 2102
4 | 2009-01-02 00:00:00 | 2102
5 | 2009-01-01 00:00:00 | 2103
6 | 2009-01-02 00:00:00 | 2103
7 | 2009-01-03 00:00:00 | 2103
(7 rows)
and then:
lem=# select min(pkid) as pkid
lem-# ,min(class_date) as class_date1
lem-# ,max(class_date) as class_date2
lem-# ,sessionid
lem-# from mytable
lem-# group by sessionid;
pkid | class_date1 | class_date2 | sessionid
------+---------------------+---------------------+-----------
5 | 2009-01-01 00:00:00 | 2009-01-03 00:00:00 | 2103
3 | 2009-01-01 00:00:00 | 2009-01-02 00:00:00 | 2102
1 | 2009-01-01 00:00:00 | 2009-01-02 00:00:00 | 2101
(3 rows)
Is this what you need or is there something else? Can you give more
sample data and the result you expect from it?
Cheers, Leo
From | Date | Subject | |
---|---|---|---|
Next Message | John | 2009-08-06 13:48:23 | Re: two records per row from query |
Previous Message | Klas Stockhem | 2009-08-06 10:00:46 | Problems when copy data from dump file |