Support for on conflict ignore returning

From: Brian McMahon <brianmcmahon135(at)gmail(dot)com>
To: pgsql-novice(at)lists(dot)postgresql(dot)org
Subject: Support for on conflict ignore returning
Date: 2024-07-30 15:53:55
Message-ID: CA+0iD35fvs6cXybmj+FSY_QWpir_c60gGzoi+GX+jTLHEf0Z-A@mail.gmail.com
Views: Whole Thread | Raw Message | Download mbox | Resend email
Thread:
Lists: pgsql-novice

Hi!

I have a question about support / if there's plans to support a feature, I
thought it would be best to send it to the "novice" mailing list because it
might be a naive question that's been answered before.

Is there a recommended way to achieve a ON CONFLICT DO NOTHING RETURNING
<column> so that conflicting columns still have information returned?
Currently it seems like the only simple way to achieve this is with a NOOP
update, so instead doing something like ON CONFLICT UPDATE SET name =
EXCLUDED.name RETURNING <column>.

As I understand it, this isn't desirable as there's various potentially
undesirable side effects since it's not treated as a NOOP, it's treated as
an update so triggers and all sorts of internal postgres logic are invoked
(which may or may not be fine for certain applications, but it's not
desirable).

Are there current features that support this functionality, or plans to
support something like this in the future?

I should probably add my use case, I need to insert a bunch of rows into
the database to ensure they exist, then for all those rows I need to update
corresponding tables that reference them with more data. If I can't make a
query that returns the primary key, then I either need to make a subsequent
query to pull all the rows from the database that weren't inserted to get
the primary keys, or I need to use the unique fields that caused the
conflict in the next query to update the tables that reference the table I
updated, which makes things a little messier (I'd rather just work with the
primary keys when possible).

Thanks in advance.

--
Sincerely,
Brian McMahon

Responses

Browse pgsql-novice by date

  From Date Subject
Next Message David G. Johnston 2024-07-30 16:00:42 Re: Support for on conflict ignore returning
Previous Message Laurenz Albe 2024-06-29 04:49:30 Re: Vacuum Analyze