Re: Question on doc for RETURNING clause

From: "Russell, John" <johrss(at)amazon(dot)com>
To: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
Cc: "pgsql-docs(at)lists(dot)postgresql(dot)org" <pgsql-docs(at)lists(dot)postgresql(dot)org>
Subject: Re: Question on doc for RETURNING clause
Date: 2024-01-11 21:11:49
Message-ID: F5C61787-5D95-4119-9C38-DE62256CECB4@amazon.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-docs

> On Jan 11, 2024, at 12:43 PM, Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> wrote:
>
> "Russell, John" <johrss(at)amazon(dot)com> writes:
>> Hi, I was thinking of suggesting some doc clarifications and additional examples related to the RETURNING clause. Just a couple of questions first to see if my understanding is correct.
>
>> I was trying to figure out what the precise “thing” is that comes back from a RETURNING clause. A table reference? A result set?
>
> I'd say it's a result set, just like the output of SELECT.
>
>> That made me think both a RETURNING clause could work in contexts such as CTE (yes) and subquery (seems like no).
>
> We disallow DML in subqueries because there's a lot of squishiness
> around when a subquery is evaluated, whether it's evaluated to
> completion, or indeed whether it's evaluated more than once.
> CTEs have tighter semantics and so it's practical to require
> "exactly once" evaluation for CTEs. Partly this is a matter of
> historical expectations, but I doubt we'd consider revisiting it.

Makes sense. I don’t mind the limitation, I was just thinking of places to document it and examples to add to illustrate usage of RETURNING. If you want to rename columns in the result set, use AS clauses for the column names in RETURNING. If you want to sort and filter what comes back from RETURNING, use a CTE and select from that. My first idea was to try a subquery for all such cases; hadn’t thought of how subqueries might get pruned, moved around, or repeated.

>>> PostgreSQL allows INSERT, UPDATE, and DELETE to be used as WITH queries. This is not found in the SQL standard.
>
>> Is MERGE allowed in that ^^^ context?
>
> Not yet, as you'd find out if you tried it. I think there's a patch
> in the pipeline to allow it.

On the way to trying it, I did see in the doc that MERGE doesn’t have a RETURNING clause, which I presume makes the point moot. If there’s a patch that adds such support in process, I won’t suggest adding “MERGE not supported” at this spot in the doc.

Thanks,
John

In response to

Browse pgsql-docs by date

  From Date Subject
Next Message Bruce Momjian 2024-01-16 22:03:06 CREATE ROLE inheritance details
Previous Message Tom Lane 2024-01-11 20:43:51 Re: Question on doc for RETURNING clause