数据库的控制
17页1、第五章数据库的控制第一节数据库恢复技术事务是一系列的数据库操作,是数据库应用程序的基本逻辑单元。事务处理技术主要 包括数据库恢复技术和并发控制技术。数据库恢复机制和并发控制机制是数据库管理系统 的重要组成部分。本章讨论数据库恢复的概念和常用技术。1.1事务的基本概念在讨论数据库恢复技术之前先讲解事务的基本概念和事务的性质。一、事务(Transaction)所谓事务是用户定义的一个数据库操作序列,这些操作要么全做要么全不做,是一个 不可分割的工作单位。例如,在关系数据库中,一个事务可以是一条SQL语句、一组SQL 语句或整个程序。事务和程序是两个概念。一般地讲,一个程序中包含多个事务。事务的开始与结束可以由用户显式控制。如果用户没有显式地定义事务,则由DBMS 按缺省规定自动划分事务。在SQL语言中,定义事务的语句有三条:BEGINTRANSACTIONCOMMITROLLBACK事务通常是以BEGINTRANSACTION开始,以COMMIT或ROLLBACK结束。COMMIT表 示提交,即提交事务的所有操作。具体地说就是将事务中所有对数据库的更新写回到磁盘 上的物理数据库中去,事务正
2、常结束。ROLLBACK表示回滚,即在事务运行的过程中发生 了某种故障,事务不能继续执行,系统将事务中对数据库的所有己完成的操作全部撤销, 滚回到事务开始时的状态。这里的操作指对数据库的更新操作。二、事务的特性事务具有四个特性:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation) 和持续性(Durability)。这个四个特性也简称为ACID特性。1. 原子性事务是数据库的逻辑工作单位,事务中包括的诸操作要么都做,要么都不做。2. 一致性事务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。因此当数 据库只包含成功事务提交的结果时,就说数据库处于一致性状态。如果数据库系统运行中 发生故障,有些事务尚未完成就被迫中断,这些未完成事务对数据库所做的修改有一部分 己写入物理数据库,这时数据库就处于一种不正确的状态,或者说是不一致的状态。例如 某公司在银行中有A,B两个账号,现在公司想从账号A中取出一万元,存入账号B。那么 就可以定义一个事务,该事务包括两个操作,第1个操作是从账号A中减去一万元,第2 个操作是向账号B中加入一万元。这两个操作
3、要么全做,要么全不做。全做或者全不做, 数据库都处于一致性状态。如果只做一个操作则用户逻辑上就会发生错误,少了一万元, 这时数据库就处于不一致性状态。可见一致性与原子性是密切相关的。3. 隔离性一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对其他并 发事务是隔离的,并发执行的各个事务之间不能互相干扰。4. 持续性持续性也称永久性(Permanence),指一个事务一旦提交,它对数据库中数据的改变就 应该是永久性的。接下来的其他操作或故障不应该对其执行结果有任何影响。事务是恢复和并发控制的基本单位。所以下面的讨论均以事务为对象。保证事务ACID特性是事务处理的重要任务。事务ACID特性可能遭到破坏的因素有:(1) 多个事务并行运行时,不同事务的操作交叉执行:(2) 事务在运行过程中被强行停止。在第一种情况下,数据库管理系统必须保证多个事务的交叉运行不影响这些事务的原 子性。在第二种情况下,数据库管理系统必须保证被强行终止的事务对数据库和其他事务 没有任何影响。这些就是数据库管理系统中恢复机制和并发控制机制的责任。1.2数据库恢复概述尽管数据库系统中采取了各种保护措施来
4、防止数据库的安全性和完整性被破坏,保证 并发事务的正确执行,但是计算机系统中硬件的故障、软件的错误、操作员的失误以及恶 意的破坏仍是不可避免的,这些故障轻则造成运行事务非正常中断,影响数据库中数据的 正确性,重则破坏数据库,使数据库中全部或部分数据丢失,因此数据库管理系统必须具 有把数据库从错误状态恢复到某一己知的正确状态(亦称为一致状态或完整状态)的功能, 这就是数据库的恢复。恢复子系统是数据库管理系统的一个重要组成部分,而且还相当庞 大,常常占整个系统代码的百分之十以上。数据库系统所采用的恢复技术是否行之有效, 不仅对系统的可靠程度起着决定性作用,而且对系统的运行效率也有很大影响,是衡量系 统性能优劣的重要指标。1.3故障的种类数据库系统中可能发生各种各样的故障,大致可以分以下几类:一、事务内部的故障事务内部的故障有的是可以通过事务程序本身发现的(见下面转账事务的例子),有的 是非预期的,不能由事务程序处理的。例如:银行转账事务,这个事务把一笔金额从一个账户甲转给另一个账户乙。BEGINTRANSACTION读账户甲的余额BALANCE;BALANCE=BALANCE-AMOUNT
《数据库的控制》由会员夏**分享,可在线阅读,更多相关《数据库的控制》请在金锄头文库上搜索。
小学六年级年度总结范文(4篇).doc
苏教版七年级语文第一次月考测试题及答案通用
产业园宣传片解说词
管理沟通讲师江磊-管理“对对碰”—如何化解管理难题
主题班会反思
银行大堂经理个人年终工作总结.doc
新概念英语1-12测试题
沥青混凝土路面施工方案(DOC43页)
电大作业《现代管理原理》参考答案
热水锅炉运行操作规程新
文秘个人求职信范文
2023年三八妇女节总结范文
中学2022—2022学年下期期末及暑假培训工作安排
用加减消元法解二元一次方程组同步练习
荆门西外环施工组织设计
优秀基层中小学校长工作经验交流
译林版二年级下册英语练习
老师给学生的毕业寄语初中
专业实习报告范文集合九篇【可编辑】
霾的原因以及危害
2022-08-06 22页
2023-03-06 5页
2023-03-06 5页
2023-02-23 5页
2022-10-21 2页
2023-11-19 8页
2022-09-27 13页
2024-02-16 4页
2024-01-10 2页
2023-11-02 44页