Re: LISTAGG à la Oracle in PostgreSQL

From: Peter Eisentraut <peter(at)eisentraut(dot)org>
To: Pierre Forstmann <pierre(dot)forstmann(at)gmail(dot)com>, "pgsql-general(at)lists(dot)postgresql(dot)org" <pgsql-general(at)lists(dot)postgresql(dot)org>
Subject: Re: LISTAGG à la Oracle in PostgreSQL
Date: 2026-03-11 13:55:53
Message-ID: 7d03be7f-9d20-4285-9342-af1d51435b5a@eisentraut.org
Views: Whole Thread | Raw Message | Download mbox | Resend email
Thread:
Lists: pgsql-general

On 09.03.26 21:21, Pierre Forstmann wrote:
> Hello,
>
> I can write a LISTAGG aggregate for:
>
> create table emp(deptno numeric, ename text);
>
> SELECT deptno, LISTAGG(ename, ','::text ORDER BY ename) AS employees
> FROM   emp GROUP BY deptno ORDER BY deptno;
>
> I would like to know if is possible to create an aggregate LISTAGG that
> would work like in Oracle:
>
> SELECT deptno,
>        listagg(ename, ',') WITHIN GROUP (ORDER BY ename) AS employees
> FROM emp
> GROUP BY deptno
> ORDER BY deptno;
>
> I failed and IA also failed. Claude says:
>
> It is not possible to exactly replicate listagg(ename, ',') WITHIN GROUP
> (ORDER BY ename) as a custom PostgreSQL aggregate
> because PostgreSQL strictly forbids ungrouped columns as direct
> arguments to ordered-set aggregates.
>
> Do you agree ?

One of the reasons that PostgreSQL hasn't implemented LISTAGG is that it
is a misdesign. It uses ordered-set aggregate syntax even
though it is not very similar to the other ordered-set aggregates.
Its syntax should be more similar to ARRAY_AGG or
JSON_ARRAYAGG, for example. But it's too late to fix the standard on this.

In response to

Browse pgsql-general by date

  From Date Subject
Next Message pierre.forstmann 2026-03-11 15:53:02 Re: LISTAGG à la Oracle in PostgreSQL
Previous Message Shiju Sivadazz 2026-03-11 13:45:08 Question about heap_inplace_update and VACUUM behavior