On 2 November 2017 at 09:33, Peter Eisentraut <peter.eisentr...@2ndquadrant.com> wrote:
> If you turned the autocommit setting off, then this code would > effectively silently do nothing, and that is obviously quite bad. Right. The example often cited is some variant of BEGIN; CREATTE TABLE t2 AS SELECT * FROM t1; DROP TABLE t1; ALTER TABLE t2 RENAME TO t1; COMMIT; Right now, we do the right thing here. With default statement level rollback, you just dropped t1 and all your data. oops. On a related note, psql's -v ON_ERROR_STOP=1 is horrible and hard to discover UI, and one of the top FAQs on Stack Overflow is some variant of "I'm getting random and incomprehensible errors restoring a dump, wtf?". So I'd really love to make it the default, but we'd face similar issues where a SQL script that's currently correct instead produces dangerously wrong results with ON_ERROR_STOP=1 . > In principle, a backend-based solution that drivers just have to opt > into would save a lot of duplication. But the drivers that care or > require it according to their standards presumably already implement > this behavior in some other way, so it comes back to whether there is a > performance or other efficiency gain here. There definitely would be over SQL-level savepoints. They're horrible for performance, especially since libpq can't yet pipeline work so you need three round-trips for each successful statement: SAVEPOINT, statement, RELEASE SAVEPOINT. It produces massive log spam too. What about if we add protocol-level savepoint support? Two new messages: BeginUnnamedSavepoint and EndUnnamedSavepoint where the latter does a rollback-to-last-unnamed-savepoint if the txn state is bad, or a release-last-unnamed-savepoint if the txn state is ok. That means the driver doesn't have to wait for the result of the statement. It knows the conn state and query outcome from our prior messages, and knows that as a result of this message any failed state has been rolled back. This would, with appropriate libpq support, give people who want statement level error handling pretty much what they want. And we could expose it in psql too. No GUCs needed, no fun surprises for apps. psqlODBC could adopt it to replace its current slow and super-log-spammy statement rollback model. Because we'd know it was a special savepoint used for statement level rollback we might still have some optimisation opportunities. Downside is that it needs support in each client driver. -- Craig Ringer http://www.2ndQuadrant.com/ PostgreSQL Development, 24x7 Support, Training & Services -- Sent via pgsql-hackers mailing list (pgsql-hackers@postgresql.org) To make changes to your subscription: http://www.postgresql.org/mailpref/pgsql-hackers