 |
» |
|
|
|
The ROLLBACK WORK statement undoes changes you have made to the DBEnvironment during
the current transaction, releases locks held by the transaction,
and closes cursors opened during the transaction. Other transactions
active in this session are not affected. Scope |  |
ISQL or Application Programs SQL Syntax |  |
ROLLBACK WORK [TO {SavePointNumber
:HostVariable
:LocalVariable
:ProcedureParameter}
RELEASE ] |
Parameters |  |
- TO
The TO clause is used to roll back to a savepoint
without ending the current transaction. If the TO clause is omitted, ROLLBACK WORK ends the current transaction and undoes any changes that
have been made in the transaction. - SavePointNumber
is the number assigned by ISQL to a savepoint when
you issue the SAVEPOINT statement interactively. - HostVariable
is defined as an integer variable to which you assign
a value when you issue the SAVEPOINT statement programmatically, or in a procedure. - LocalVariable
contains a value in a procedure. - ProcedureParameter
contains a value that is passed into or out of a
procedure. - RELEASE
terminates your DBE session.
Description |  |
When you omit the
TO clause, all changes you have made to the DBEnvironment since the
most recent BEGIN WORK statement are undone. In an application program, all
open cursors are automatically closed except those opened with the
KEEP CURSOR option. Any savepoints defined in the transaction are
lost and become invalid. The transaction is ended. Any cursor opened
with the KEEP CURSOR option is repositioned to its scan position
as of the most recent BEGIN WORK statement, and a new transaction is implicitly started
with the same isolation level. The TO clause may not be used if any cursors that
were opened with the KEEP CURSOR option are still open. Issuing
a ROLLBACK WORK to a savepoint in this context results in an error message,
and no rollback is done. When you specify the TO clause, all changes you
have made to the DBEnvironment since the designated savepoint are
undone. If any cursors opened with the KEEP CURSOR option were active
in this transaction, the statement fails and the rollback is not
done. In an application program or procedure, all open cursors are
automatically closed. Any savepoints defined more recently than the designated
savepoint are lost and become invalid. The designated savepoint
is still valid and can be specified in a future ROLLBACK WORK statement. The transaction is not ended. Any locks obtained
since the savepoint was set are released. If the current transaction is the one in which you
opened a cursor with the KEEP CURSOR option, then the ROLLBACK WORK statement closes the cursor and undoes any changes made
through it. Under some circumstances ALLBASE/SQL automatically
rolls back a transaction. For example, when service is restored
after a system failure, all uncommitted transactions are automatically
backed out. If RELEASE is used, all cursors are closed and the
current connection is terminated. The RELEASE option is not allowed within a procedure.
Authorization |  |
You do not need authorization to use the ROLLBACK WORK 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.
|