收藏本站 
广告服务 
网站地图 
>> 本频道近100000余篇各类电脑技术、网络技术、软件技术、网页及平面设计等方面的电脑教程,我们的原则:不是精华拒不收录!
先飞电脑技术网技术文章数据库开发Oracle
网络编程 | 网站建设 | 网络技术 | 设计教程 | 软件教学 | 程序开发 | 数据库开发 | 教育认证 | 硬件维护 | 媒体动画 | 机械电子 |

轻松掌握Oracle中事务管理的概念

[ 作者:佚名    转贴自:网络转载    阅读次数:49    更新时间:2007-10-4 13:41:00   录入:刘光勇 ]        
    在Oracle中一个事务是由一个可执行的SQL语句开始,一个可执行SQL语句产生对实例的调用。在事务开始时,被赋给一个可用回滚段,记录该事务的回滚项。一个事务以下列任何一个出现而结束。

◆当COMMIT或ROLLBACK(没有SAVEPOINT子句)语句发出。

◆一个DDL语句被执行。在DDL语句执行前、后都隐式地提交。

◆用户撤消对Oracle的连接(当前事务提交)。

◆用户进程异常中止(当前事务回滚)。

(1)提交事务

提交一事务,即将在事务中由SQL语句所执行的改变永久化。在提交前,Oracle已有下列情况:

◆在SGA的回滚段缓冲区已生成回滚段记录,回滚信息包含有所修改值的老值。

◆在SGA的日志缓冲区已生成日志项。这些改变在事务提交前可进入磁盘。

◆对SGA的数据库缓冲区已作修改,这些修改在事务真正提交之前可进入磁盘。

在事务提交之后,有下列情况:

◆对于与回滚段相关的内部事务表记录提交事务,并赋给一个相应的唯一系统修改号(SCN),记录在表中。

◆在SGA的日志缓冲区中日志项由LGWR进程写入到在线日志文件, 这是构成提交事务的原子事务。

◆在行上和表上的封锁被释放。

◆该事务标志为完成 。

注意:对于提交事务的数据修改不必由DBWR后台进程立即写入数据文件,可继续存储在SGA的数据库缓冲区中,在最有效时将其写入数据文件。

(2)回滚事务

回滚事务的含义是撤消未提交事务中的SQL语句所作的对数据修改。Oracle允许撤消未提交的整个事务,也允许撤消部分。

在回滚整个事务(没有引用保留点)时,有下列情况:

◆在事务中所有SQL语句作的全部修改,利用相应的回滚段被撤消。

◆所有数据的事务封锁被释放。

◆事务结束。

◆当事务回滚到一保留点(具有SAVEPOINT)时,有下列情况:

◆仅在该保留点之后执行的语句被撤消。

◆该指定的保留点仍然被保留,该保留点之后所建立的保留点被删除。

◆自该保留点之后所获取的全部表封锁和行封锁被释放,但指定的保留点以前所获取的全部数据封锁继续保持。

◆该事务仍可继续。

(3)保留点

保留点(savepoint)是在一事务范围内的中间标志,经常用于将一个长的事务划分为小的部分。保留点可标志长事务中的任何点,允许可回滚该点之后的工作。在应用程序中经常使用保留点;例如一过程包含几个函数,在每个函数前可建立一个保留点,如果函数失败,很容易返回到每一个函数开始的情况。在回滚到一个保留点之后,该保持点之后所获得的数据封锁被释放。

文章首页【加入到收藏夹】告诉好友】【打印此文】【关闭窗口
  版权声明:本站提供的“轻松掌握Oracle中事务管理的概念”版权归文章所有者,转载请注明出处!
 ·上一篇文章:存储在数据库中的过程——数据库触发器      ·下一篇文章:Oracle数据库最重要的部分之一数据字典
相关文章
·Excel 2007中轻松设置文本的样式[40]
·轻松掌握在SQL Server中删除群集[37]
·在Office 2007中轻松绘制斜线表头[75]
·轻松掌握什么是数据的物理(存储)结构[79]
·带你轻松接触多线索机制概念[108]
网站主页 | 收藏本页 | 联系我们 | 广告服务 | 站点地图 | 会员注册 | 招聘信息 | 内容指正

联系QQ:先飞电脑技术网站事务联系QQ,点击可以直接留言. 32933427 电话:13710542091 [世界排名] 鄂ICP备05005890号 先飞电脑教程网