The SAVEPOINT statement defines a savepoint within a transaction. DBEnvironment changes
made after a savepoint can be undone at any time prior to the end
of the transaction. A transaction can have multiple savepoints.
Scope |
 |
ISQL or Application Programs
SQL Syntax |
 |
SAVEPOINT [:HostVariable
:LocalVariable
:ProcedureParameter] |
Parameters |
 |
- HostVariable
identifies an output host variable used to communicate
the savepoint number. The host variable's value can be from 1 to
(231)-1. In an application program,
you must use a host variable with the SAVEPOINT statement. In a procedure, you must use either a local
variable or a procedure parameter with the SAVEPOINT statement.
When you enter a SAVEPOINT statement interactively, you cannot specify a host variable.
ISQL assigns and displays the savepoint number as follows:
isql=> savepoint;
Savepoint number is n.
Use this number to do ROLLBACK WORK to n.
|
- LocalVariable
contains a value in a procedure. Identifies an output
host variable used to communicate the savepoint number. The host
variable's value can be from 1 to (231)-1.
- ProcedureParameter
contains a value that is passed into or out of a
procedure. Identifies an output host variable used to communicate
the savepoint number. The host variable's value can be from 1 to
(231)-1.
Description |
 |
Specify the savepoint
number in the TO clause of a ROLLBACK WORK statement to roll back to a savepoint.
If a procedure invoked by a rule executes a COMMIT WORK statement, an error occurs.
Authorization |
 |
You do not need authorization to use the SAVEPOINT statement.
Example |
 |
Transaction begins.
BEGIN WORK
statement-1
SAVEPOINT :MyVariable
statement-2
statement-3
|
Work of statements 2 and 3 is undone.
ROLLBACK WORK
TO :MyVariable
|
Work of statement-1 is committed; transaction ends.