Re: Current transaction is aborted, commands ignored until end of transaction block

From: Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us>
To: Jan Bakuwel <jan(dot)bakuwel(at)greenpeace(dot)org>
Cc: pgsql-sql(at)postgresql(dot)org
Subject: Re: Current transaction is aborted, commands ignored until end of transaction block
Date: 2011-12-30 23:19:27
Message-ID: 26063.1325287167@sss.pgh.pa.us
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-sql

Jan Bakuwel <jan(dot)bakuwel(at)greenpeace(dot)org> writes:
> Why-o-why have the PostgreSQL developers decided to do it this way...?

Because starting and cleaning up a subtransaction is an expensive thing.
If we had auto-rollback at the statement level, you would be paying that
overhead for every statement in every transaction, whether you need it
or not (since obviously there's no way to forecast in advance whether a
statement will fail). Making it depend on explicit savepoints allows
the user/application to control whether that overhead is expended or
not.

If you want to pay that price all the time, there are client-side
frameworks that will do it for you, or you can roll your own easily
enough. So we do not see it as a big deal that the database server
itself doesn't act that way.

regards, tom lane

In response to

Responses

Browse pgsql-sql by date

  From Date Subject
Next Message Scott Marlowe 2011-12-31 00:03:15 Re: Current transaction is aborted, commands ignored until end of transaction block
Previous Message Jan Bakuwel 2011-12-30 22:51:41 Re: Current transaction is aborted, commands ignored until end of transaction block