From: | Jeff Davis <pgsql(at)j-davis(dot)com> |
---|---|
To: | Dean Rasheed <dean(dot)a(dot)rasheed(at)gmail(dot)com> |
Cc: | Isaac Morland <isaac(dot)morland(at)gmail(dot)com>, PostgreSQL Hackers <pgsql-hackers(at)lists(dot)postgresql(dot)org> |
Subject: | Re: MERGE ... RETURNING |
Date: | 2023-07-13 19:14:52 |
Message-ID: | d200e6b4cf17f19d804b79d02d80567cb9889c00.camel@j-davis.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-hackers |
On Thu, 2023-07-13 at 18:01 +0100, Dean Rasheed wrote:
> For some use cases, I can imagine allowing OLD/NEW.colname would mean
> you wouldn't need pg_merge_action() (if the column was NOT NULL), so
> I
> think the features should work well together.
For use cases where a user could do it either way, which would you
expect to be the "typical" way (assuming we supported the new/old)?
MERGE ... RETURNING pg_merge_action(), id, val;
or
MERGE ... RETURNING id, OLD.val, NEW.val;
?
I am still bothered that pg_merge_action() is so context-sensitive.
"SELECT pg_merge_action()" by itself doesn't make any sense, but it's
allowed in the v8 patch. We could make that a runtime error, which
would be better, but it feels like it's structurally wrong. This is not
an objection, but it's just making me think harder about alternatives.
Maybe instead of a function it could be a special table reference like:
MERGE ... RETURNING MERGE.action, MERGE.action_number, id, val?
Regards,
Jeff Davis
From | Date | Subject | |
---|---|---|---|
Next Message | Gurjeet Singh | 2023-07-13 19:54:26 | Re: Fix search_path for all maintenance commands |
Previous Message | Farias de Oliveira | 2023-07-13 19:14:32 | In Postgres 16 BETA, should the ParseNamespaceItem have the same index as it's RangeTableEntry? |