Re: BUG #19516: Mixup of OLD/NEW with RETURNING when parenthesized

From: Marko Grujic <markoog(at)gmail(dot)com>
To: pgsql-bugs(at)lists(dot)postgresql(dot)org
Subject: Re: BUG #19516: Mixup of OLD/NEW with RETURNING when parenthesized
Date: 2026-06-10 10:50:39
Message-ID: CAKQrOnpOSFrQ=cdSeHfoBFOwNT3=aa55t2VRZMt_xeOf9dMO8Q@mail.gmail.com
Views: Whole Thread | Raw Message | Download mbox | Resend email
Thread:
Lists: pgsql-bugs

Proposed patch:
https://www.postgresql.org/message-id/CAOvwyF2cO_5mAt%3Dw%3Dy-dFnaG5UkZ%2B3H8nSDoKF_iuWZHsU2ARg%40mail.gmail.com

On Wed, Jun 10, 2026 at 12:10 PM PG Bug reporting form <
noreply(at)postgresql(dot)org> wrote:

> The following bug has been logged on the website:
>
> Bug reference: 19516
> Logged by: Marko Grujic
> Email address: markoog(at)gmail(dot)com
> PostgreSQL version: 18.4
> Operating system: MacOS, Debian
> Description:
>
> Hi, reporting a basic bug which involves a RETURNING clause on DML with
> parenthesized OLD/NEW.
>
> Effectively, the (parenthesized) row reference isn't being honored, and
> instead the default behavior is applied.
>
> Seeing this on tip of master as well (19beta1).
>
> postgres=# create table t(a int, b text);
> CREATE TABLE
> postgres=# insert into t values (1, 'one') returning (old).b, old.b,
> (new).b, new.b;
> b | b | b | b
> -----+---+-----+-----
> one | | one | one
> (1 row)
>
> INSERT 0 1
> postgres=# update t set b = '1' where a = 1 returning (old).b, old.b,
> (new).b, new.b;
> b | b | b | b
> ---+-----+---+---
> 1 | one | 1 | 1
> (1 row)
>
> UPDATE 1
> postgres=# delete from t where a = 1 returning (old).b, old.b, (new).b,
> new.b;
> b | b | b | b
> ---+---+---+---
> 1 | 1 | 1 |
> (1 row)
>
> DELETE 1
> postgres=# select version();
> version
>
> --------------------------------------------------------------------------------------------------------------------
> PostgreSQL 18.4 (Debian 18.4-1.pgdg13+1) on x86_64-pc-linux-gnu, compiled
> by gcc (Debian 14.2.0-19) 14.2.0, 64-bit
> (1 row)
>
>
>

In response to

Browse pgsql-bugs by date

  From Date Subject
Next Message Matheus Alcantara 2026-06-10 11:08:56 Re: BUG #19484: Segmentation fault triggered by FDW
Previous Message PG Bug reporting form 2026-06-10 10:09:51 BUG #19516: Mixup of OLD/NEW with RETURNING when parenthesized