1、第七章 数据库恢复技术,7.1 事务的基本概念,一、事务(Transaction)所谓事务是用户定义的一个数据库操作序列,这些操作要么全做要么全不做,是一个不可分割的工作单位。 例如,在关系数据库中,一个事务可以是一条SQL语句、一组SQL语句或整个程序。,事务的开始与结束可以由用户显式控制。 如果用户没有显式地定义事务,则由DBMS按缺省规定自动划分事务。 在SQL语言中,定义事务的语句有三条:BEGIN TRANSACTIONCOMMITROLLBACK,COMMIT表示提交,即提交事务的所有操作。具体地说就是将事务中所有对数据库的更新写回到磁盘上的物理数据库中去,事务正常结束。 ROLL
2、BACK表示回滚,即在事务运行的过程中发生了某种故障,事务不能继续执行,系统将事务中对数据库的所有已完成的操作全部撤销,滚回到事务开始时的状态。,二、事务的特性,事务具有四个特性( ACID特性):原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持续性(Durability)。 1原子性 事务是数据库的逻辑工作单位,事务中包括的诸操作要么都做,要么都不做。,2一致性事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。 当数据库只包含成功事务提交的结果时,就说数据库处于一致性状态。 如果数据库系统运行中发生故障,有些事务尚未完成就被迫中
3、断,这些未完成事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说是不一致的状态。 一致性与原子性是密切相关的。,3隔离性一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对其他并发事务是隔离的,并发执行的各个事务之间不能互相干扰。 4持续性持续性也称永久性(Permanence),指一个事务一旦提交,它对数据库中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其执行结果有任何影响。,事务ACID特性可能遭到破坏的因素有:(1)多个事务并发运行时,不同事务的操作交叉执行;(2)事务在运行过程中被强行停止。,72数据库恢复概述,数据库的恢复:数据库管理系统必须具有把数据库从错误状态恢复到某一已知的正确状态(亦称为一致状态或完整状态)的功能,这就是数据库的恢复。 恢复子系统是数据库管理系统的一个重要组成部分,而且还相当庞大,常常占整个系统代码的百分之十以上。 数据库系统所采用的恢复技术是否行之有效,不仅对系统的可靠程度起着决定性作用,而且对系统的运行效率也有很大影响,是衡量系统性能优劣的重要指标。,