Re: LISTAGG à la Oracle in PostgreSQL

From: Pavel Stehule <pavel(dot)stehule(at)gmail(dot)com>
To: Juan Rodrigo Alejandro Burgos Mella <rodrigoburgosmella(at)gmail(dot)com>
Cc: Pierre Forstmann <pierre(dot)forstmann(at)gmail(dot)com>, Paul A Jungwirth <pj(at)illuminatedcomputing(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-10 21:46:59
Message-ID: CAFj8pRB-GUcyjBEOLKoHUcmkR7TWjmfEJk-9gAKYs7o_uhYyuw@mail.gmail.com
Views: Whole Thread | Raw Message | Download mbox | Resend email
Thread:
Lists: pgsql-general

út 10. 3. 2026 v 21:23 odesílatel Pavel Stehule <pavel(dot)stehule(at)gmail(dot)com>
napsal:

> Hi
>
> út 10. 3. 2026 v 20:58 odesílatel Juan Rodrigo Alejandro Burgos Mella <
> rodrigoburgosmella(at)gmail(dot)com> napsal:
>
>> To do something similar, you would have to fork the source code and
>> implement the declarations with the same syntax, resulting in something
>> like Postracle.
>>
>
> orafce has listagg function https://github.com/orafce/orafce
>

but it doesn't support syntax WITHING GROUP syntax. Probably there is not a
possibility to implement it in extension without introducing a new kind of
aggregate functions in core, or enhancing behaviour of ordered-set kind of
aggregates.

Regards

Pavel

> Regards
>
> Pavel
>
>
>>
>> Atte
>> JRBM
>>
>> El mar, 10 mar 2026 a las 13:53, Pierre Forstmann (<
>> pierre(dot)forstmann(at)gmail(dot)com>) escribió:
>>
>>> I agree but I just would like to know if there is way to be compatible
>>> with Oracle syntax using aggregate features in PostgreSQL
>>>
>>> Thanks.
>>>
>>> Le 09/03/2026 à 23:05, Paul A Jungwirth a écrit :
>>> > On Mon, Mar 9, 2026 at 1:21 PM Pierre Forstmann
>>> > <pierre(dot)forstmann(at)gmail(dot)com> 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 don't think you need a custom aggregate here. In Postgres you can
>>> say:
>>> >
>>> > select deptno,
>>> > string_agg(ename, ',' ORDER BY ename) AS employees
>>> > FROM emp
>>> > GROUP BY deptno
>>> > ORDER BY deptno;
>>> >
>>>
>>>
>>>

In response to

Responses

Browse pgsql-general by date

  From Date Subject
Next Message Pratibha Shende 2026-03-11 08:19:18 Guidance on PgSql Upgrade from 17.3 to 18.2
Previous Message Pavel Stehule 2026-03-10 20:23:14 Re: LISTAGG à la Oracle in PostgreSQL