处理 DB2 数据 COMMIT 和 ROLLBACK 语句和事务边界

简介:

工作单元和保存点

工作单元(unit of work,UOW) 也称为事务,它是应用程序进程中一个可恢复的(recoverable) 操作序列。UOW 的经典示例是简单的银行转帐事务,即把资金从一个帐号转到另一个帐号中。在应用程序从一个帐号减去一定数量的资金之后,数据库会出现不一致的状态;在第二个帐号中增加同样数量的资金之后,这种不一致才会消除。当这些修改已经提交之后,其他应用程序才能使用它们。

当应用程序进程中的第一个 SQL 语句对数据库发出时,一个 UOW 隐式地开始。同一个应用程序后续的所有读写操作被认为是同一个 UOW 的一部分。应用程序可以在适当的时候发出 COMMIT 或 ROLLBACK 语句来结束 UOW。COMMIT 语句将这个 UOW 中所做的所有修改持久化,而 ROLLBACK 语句撤消这些修改。如果应用程序正常地结束,而没有发出显式的 COMMIT 或 ROLLBACK 语句,那么 UOW 会自动地提交。如果应用程序在 UOW 结束之前意外地终止,那么这个工作单元会自动地回滚。

保存点(savepoint) 允许选择性地回滚组成 UOW 的操作子集,这样就不会丢失整个事务。可以嵌套保存点并可以同时拥有几个活跃的 保存点级别(savepoint level);这允许应用程序根据需要回滚到特定的保存点。假设在某个 UOW 中定义了三个保存点(A、B 和 C):

do some work;
            savepoint A;
            do some more work;
            savepoint B;
            do even more work;
            savepoint C;
            wrap it up;
            roll back to savepoint B;
            

回滚到保存点 B 会自动地释放保存点 C,但是保存点 A 和 B 仍然是活跃的。


本文转自tiasys博客园博客,原文链接:http://www.cnblogs.com/tiasys/archive/2009/02/27/1399358.html,如需转载请自行联系原作者

相关文章
|
9月前
|
SQL 关系型数据库 MySQL
MySQL数据库——事务操作-begin-commit-rollback
MySQL数据库——事务操作-begin-commit-rollback
75 1
|
3天前
|
SQL Oracle 关系型数据库
【YashanDB知识库】update/delete未选中行时,v$transaction视图没有事务,alter超时问题
在22.2.8.3版本中,执行`alter table`修改表字段名时出现超时问题。经分析发现,当`delete`或`update`未选中行时,`v$transaction`中无事务记录但存在TS锁,导致`alter table`操作卡住并超时。通过设置`DDL_LOCK_TIMEOUT`参数为0可立即返回timeout报错。经验总结:`delete`、`update`未选中行时,`v$transaction`无记录但有TS锁,此时`alter table`会返回lock wait timeout错误,属于正常现象。
|
Oracle 关系型数据库
【Oracle】-【隐式commit】-正常与异常退出对commit的作用
create table my_objects as select * from all_objects; commit; select count(*) from my_objects;   COUNT(*) ----------       8587 delete from my_objects; 8587 rows deleted.
791 0
|
SQL Oracle 关系型数据库
【Oracle】-【COMMIT对索引的影响】-从trace看COMMIT对索引的影响
之前看过老杨http://yangtingkun.itpub.net/post/468/231000的一篇文章,讲述了INSERT操作对全文索引无操作,但DELETE时为了防止删除的数据仍能通过索引的ROWID访问产生的错误,此时会进行索引的删除操作,因此大批量的DELETE-COMMIT就会耗时,甚至导致数据库挂起。
906 0
|
缓存 Oracle 关系型数据库
Oracle中控制commit的三个参数 commit_write, commit_logging和 commit_wait
Oracle中控制commit的动作有三个参数 commit_write, commit_logging和 commit_wait,按重要性分别说明如下
362 0
|
SQL Oracle 关系型数据库
DDL会产生两次commit操作
DDL操作为什么需要两次commit操作呢?
|
SQL 存储 关系型数据库
事务控制语句,begin,rollback,savepoint,隐式提交的SQL语句
事务控制语句 在MySQL命令行的默认设置下,事务都是自动提交的,即执行SQL语句后就会马上执行COMMIT操作。因此开始一个事务,必须使用BEGIN、START TRANSACTION,或者执行SET AUTOCOMMIT=0,以禁用当前会话的自动提交。
1805 0