Re: Question regarding how databases support atomicity - Mailing list pgsql-general

From David G. Johnston
Subject Re: Question regarding how databases support atomicity
Date
Msg-id CAKFQuwb2MtE02QgMQ3vvLOj7bvGMar6qwnigCBBaYLBKsdk3xg@mail.gmail.com
Whole thread Raw
In response to Re: Question regarding how databases support atomicity  (Siddharth Jain <siddhsql@gmail.com>)
Responses Re: Question regarding how databases support atomicity
Re: Question regarding how databases support atomicity
List pgsql-general
On Friday, May 3, 2024, Siddharth Jain <siddhsql@gmail.com> wrote:


On Fri, May 3, 2024 at 8:00 PM Siddharth Jain <siddhsql@gmail.com> wrote:
I am trying to sharpen my understanding of databases. Let's say there is an operation foo as part of the public API that internally translates to more than 1 operation - I am sure there are examples like this in postgres. So to do foo we have to do following in order in all or none fashion:

1. Step 1
2. Step 2
3. Step 3

The way I understand this is that if there is a failure in-between, we start undoing and reverting the previous operations one by one.

Not in PostgreSQL.  All work performed is considered provisional until a commit succeeds.  At which point all provisional work, which had been tagged with the same transaction identifier, becomes reality to the rest of the system, by virtue of marking the transaction live.  If the commit never happens, either because of error, rollback, or session end, the transaction ends up being left unalive and eventually is cleaned up.

You need to ensure a “begin” happens before Step 1 and a “commit” after Step 3.

David J.

pgsql-general by date:

Previous
From: Siddharth Jain
Date:
Subject: Re: Question regarding how databases support atomicity
Next
From: "David G. Johnston"
Date:
Subject: Re: Question regarding how databases support atomicity