| From: | Peter Geoghegan <pg(at)bowt(dot)ie> | 
|---|---|
| To: | Aleksander Alekseev <aleksander(at)timescale(dot)com> | 
| Cc: | PostgreSQL Hackers <pgsql-hackers(at)lists(dot)postgresql(dot)org>, Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>, Andres Freund <andres(at)anarazel(dot)de> | 
| Subject: | Re: [PATCH] Make ON CONFLICT DO NOTHING and ON CONFLICT DO UPDATE consistent | 
| Date: | 2023-01-25 19:08:04 | 
| Message-ID: | CAH2-Wz=T-pdQNo0k7-+FQxs3OcMVP3Td1NhZ0n3afP1C-g=4Ag@mail.gmail.com | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-hackers | 
On Wed, Jan 25, 2023 at 11:01 AM Aleksander Alekseev
<aleksander(at)timescale(dot)com> wrote:
> Just to make sure we are on the same page. The patch doesn't break the
> current DO NOTHING behavior but rather makes DO UPDATE work the same
> way DO NOTHING does.
It also makes DO UPDATE not work the same way as either UPDATE itself
(which will silently skip a second or subsequent update of the same
row by the same UPDATE statement in RC mode), or MERGE (which has
similar cardinality violations).
DO NOTHING doesn't lock any conflicting row, and so won't have to
dirty pages that have matching rows. It was always understood to be
more susceptible to certain issues (when in READ COMMITTED mode) as a
result. There are some halfway reasonable arguments against this sort
of behavior, but I believe that we made the right trade-off.
-- 
Peter Geoghegan
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Mahmoud Sakr | 2023-01-25 19:11:33 | Re: Implement missing join selectivity estimation for range types | 
| Previous Message | Christoph Moench-Tegeder | 2023-01-25 19:06:50 | Re: pg_upgrade from PG-14.5 to PG-15.1 failing due to non-existing function |