Required privileges
No privileges are required to create a savepoint. However, privileges are required for each statement within a transaction.Syntax
Parameters
The name of the savepoint. Nested transactions can use any name for the savepoint. Retry savepoints default to using the name
cockroach_restart, but this can be customized using a session variable.Examples
The examples below use the following table:Basic usage
To establish a savepoint inside a transaction:Due to the rules for identifiers in the SQL grammar,
SAVEPOINT foo and SAVEPOINT Foo define the same savepoint, whereas SAVEPOINT "Foo" defines another.RELEASE SAVEPOINT:
(1,1) and (3,3) into the table, but not (2,2):
Savepoints for nested transactions
Transactions can be nested using named savepoints.RELEASE SAVEPOINT and ROLLBACK TO SAVEPOINT can both refer to a savepoint “higher” in the nesting hierarchy. When this occurs, all of the savepoints “under” the nesting are automatically released / rolled back too.
Specifically:
- When a previous savepoint is rolled back, the statements entered after that savepoint are also rolled back.
- When a previous savepoint is released, it commits; the statements entered after that savepoint are also committed.
Multi-level rollback with ROLLBACK TO SAVEPOINT
Savepoints can be arbitrarily nested, and rolled back to the outermost level so that every subsequent statement is rolled back. For example, this transaction does not insert anything into the table. BothINSERTs are rolled back:
Multi-level commit with RELEASE SAVEPOINT
Changes committed by releasing a savepoint commit all of the statements entered after that savepoint. For example, the following transaction inserts both(2,2) and (4,4) into the table when it releases the outermost savepoint:
Multi-level rollback and commit in the same transaction
Changes partially committed by a savepoint release can be rolled back by an outer savepoint. For example, the following transaction inserts only value(5, 5). The values (6,6) and (7,7) are rolled back.
Error recovery in nested transactions
IfROLLBACK TO SAVEPOINT is used after a database error, it can also cancel the error state of the transaction. Database errors move a transaction (or nested transaction) into an “Aborted” state. In this state, the transaction will not execute any further SQL statements.
You can use ROLLBACK TO SAVEPOINT to recover from a logical error in a nested transaction. Logical errors include:
- Unique index error (duplicate row)
- Failed foreign key constraint check (row does not exist in referenced table)
- Mistakes in queries (reference a column that does not exist)
SHOW TRANSACTION STATUS statement.
For example:
Savepoint name visibility
The name of a savepoint that was rolled back over is no longer visible afterward. For example:See also
- RELEASE SAVEPOINT
- ROLLBACK
- BEGIN
- COMMIT
- SHOW SAVEPOINT STATUS
- Transactions