1、第 八 章 数据保护之 事务和锁 8.3 事 务处 理 8.4 锁 * C+面向对象程序设计8.3 事务处理n 一、 事务简介n 1.事务由来n 2 . 什么是事务n 3.事务属性及分类n 二、管理事务n 1. 隐性事务 n 2 . 自动提交事务 n 3 . 显式事务 n 一、 事务简介1事务由来使用 DELETE 命令或 UPDATE 命令对数据库进行更新时一次只能操作一个表,这会带来数据库的数据不一致的问题( 即使已经设置级联删除或修改,计算机内部也是分别先后删除每一个表 )。例如:在FACTORY 数据库中,若取消了 “市场部 ”,需要将 市场部 从 depart表中删除,要修改 dep
2、art 表,而WORKER表中的部门号与市场部相对应的职工也应删除。因此,两个表都需要修改 ,这种修改只能通过两条DELETE 语句进行。假设市场部编号为 3第一条 DELETE 语句修改 depart 表delete from departwhere 部门号 = 3第二条 DELETE 语句修改 WORKER 表delete from WORKER where 部门号 = 3 在执行第一条 DELETE 语句后,数据库中的数据已处于不一致的状态,因为此时已经没有 “市场部 ”了,但 WORKER表中仍然保存着属于 “市场部 ”的员工记录。只有执行了第二条 DELETE 语句后数据才重新处于一
3、致状态。但是,如果执行完第一条语句后,计算机突然出现故障,无法再继续执行第二条 DELETE 语句,则数据库中的数据将处于永远不一致的状态。因此,必须保证这两条 DELETE 语句同时执行。为解决类似的问题,数据库系统通常都引入了事务( Transaction) 的概念。2.什么是事务事务是单独的逻辑工作单元,也是一个操作序列,该单元中可以包含多个操作以完成一个完整的任务。如果事务成功,在事务中所做的所有的操作都会在提交时完成并且永久地成为数据库的一部分。如果事务遇到错误,则必须取消或回滚,这样所有的操作都将被消除,就象什么也没有执行过一样。 事务作为一个整体,只有两种状态 :要么成功,要么失
4、败。 事务具有 ACID属性:n 原子性 (Atomicity)n 一致性 (Consistency)n 隔离性 (Isolation)n 持续性 (Duration)n 事务可以分为显式事务和自动提交事务、隐式事务。3.事务属性及分类n 1.显式事务n 2 . 自动提交事务 n 3 .隐性事务 二、 管理事务 1. 显式事务 在显式事务中,事务的语句在BEGIN TRANSACTION和COMMIT TRANSACTION子句间组成一组。使用下列四条语句来管理事务:n (1)BEGIN TRANSACTIONn (2)COMMIT TRANSACTIONn (3)ROLLBACK TRANS
5、ACTIONn (4)SAVE TRANSACTION 1).BEGIN TRANSACTION标记一个显式本地事务的起始点, SQL Server可使用该语句来开始一个新的事务。语法格式如下:BEGIN TRAN SACTION transaction_name | tran_name_variable WITH MARK description n 注意:任何有效的用户都具有默认的 BEGIN TRANSACTION权限。 2).COMMIT TRANSACTIONCOMMIT TRANSACTION标志一个成功的隐性事务或显示事务的结束。语法格式如下:COMMIT TRAN SACTION transaction_name | tran_name_variable n 注意:事务的提交使得占用的资源被释放,所做的修改在数据库中成为永久有效。