From: | Richard Huxton <dev(at)archonet(dot)com> |
---|---|
To: | Michael Toews <mwtoews(at)sfu(dot)ca> |
Cc: | pgsql-sql(at)postgresql(dot)org |
Subject: | Re: order function in aggregate |
Date: | 2008-07-30 17:28:28 |
Message-ID: | 4890A4BC.1030404@archonet.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-sql |
Michael Toews wrote:
> Now, I would like to group a summary of the strings in "sub", but they
> must be ordered alphabetically. Here I attempt the SQL:
>
> select commacat(sub), grp from aggr_test group by grp;
>
> However, on my system it will output the "commacat" column as:
>
> "one, two, three";"pom pom"
> "two, three, one";"la la"
>
> (notice that the items in the first column are ordered differently,
> since the input values were entered in non-alphabetically)
>
> This is where I get confused, since in the aggregate function, I have
> specified `SORTOP="<"`, which according to the documentation
> (http://www.postgresql.org/docs/8.3/interactive/sql-createaggregate.html)
> "must be equivalent to":
>
> SELECT sub FROM aggr_test ORDER BY sub USING <; -- LIMIT 1;
That's for things like min()/max() where you only want the first/last
value of some set. You want all of them.
You could accumulate the values in an array and then sort that with the
final-func that create aggregate supports.
--
Richard Huxton
Archonet Ltd
From | Date | Subject | |
---|---|---|---|
Next Message | Tom Lane | 2008-07-30 17:45:18 | Re: order function in aggregate |
Previous Message | Emi Lu | 2008-07-30 15:32:08 | Re: Get day name(Mon, Tue... Sun) and day number (1, 2...7) from a date |