刘淳-数据库系统原理与应用第6章节数据库的事务处理与数据恢复

刘淳-数据库系统原理与应用第6章节数据库的事务处理与数据恢复

ID:43829384

大小:4.49 MB

页数:76页

时间:2019-10-15

刘淳-数据库系统原理与应用第6章节数据库的事务处理与数据恢复_第1页
刘淳-数据库系统原理与应用第6章节数据库的事务处理与数据恢复_第2页
刘淳-数据库系统原理与应用第6章节数据库的事务处理与数据恢复_第3页
刘淳-数据库系统原理与应用第6章节数据库的事务处理与数据恢复_第4页
刘淳-数据库系统原理与应用第6章节数据库的事务处理与数据恢复_第5页
资源描述:

《刘淳-数据库系统原理与应用第6章节数据库的事务处理与数据恢复》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、第6章数据库的事务处理与数据恢复6.1事务管理的基本概念6.2并发控制6.3数据库恢复尚辅网http://shangfuwang.com/6.1事务管理的基本概念6.1.1事务(Transaction)的概念6.1.2事务的状态6.1.3事务的特性6.1.4SQLServer中的事务返回首页尚辅网http://shangfuwang.com/6.1.1事务(Transaction)的概念事务是用户定义的数据库操作序列,这些操作可作为一个完整的工作单元。一个事务内的所有语句是一个整体,要么全部执行,要么全部不执行。即事务是不可再分的原子性工作。如在

2、银行业务中,“从帐户A转移资金X到帐户B”就是一个典型的事务。这个事务可以分解为两个动作:(1)从账户A减去金额X。(2)在账户B中加上金额X。返回本节尚辅网http://shangfuwang.com/6.1.2事务的状态事务的基本操作包括:(1)事务开始(BEGIN_TRANSACTION)。事务开始执行。(2)事务读写(Read/Write)。事务进行数据操作。(3)事务结束(END_TRANSACTION)。事务完成所有的读/写操作。(4)事务交付(COMMIT_TRANSACTION)。事务完成所有的读/写操作,并保存操作结果。尚辅网h

3、ttp://shangfuwang.com/返回本节尚辅网http://shangfuwang.com/6.1.3事务的特性事务所必须具有的重要特性包括:(1)原子性(Atomicity)。(2)一致性(Consistency)。(3)隔离性(Isolation)。(4)持久性(Durability)。尚辅网http://shangfuwang.com/上述的四个特性也简称为ACID特性,保证ACID特性是事务处理的重要任务。事务的ACID特性可能遭到破坏的原因有:1)多个事务并行运行时,不同事务的操作交叉执行。2)事务在运行过程中被强迫停止。返

4、回本节尚辅网http://shangfuwang.com/6.1.4SQLServer中的事务SQLServer的事务分为两种类型:系统提供的事务和用户定义的事务。系统提供的事务是指在执行某些语句时,一条语句就是一个事务,它的数据对象可能是一个或多个表(视图),可能是表(视图)中的一行数据或多行数据;用户定义的事务以BEGINTRANSACTION语句开始,以COMMIT或ROLLBACK结束。尚辅网http://shangfuwang.com/其中:BEGINTRANSACTION:事务的开始标记。COMMITTRANSACTION:事务的结束

5、标记。OLLBACKTRANSACTION:回滚。返回本节尚辅网http://shangfuwang.com/6.2并发控制6.2.1并发操作引起的问题6.2.2封锁6.2.3封锁出现的问题及解决方法6.2.4可串行化调度6.2.5SQLServer的并发控制机制返回首页尚辅网http://shangfuwang.com/6.2.1并发操作引起的问题对事务的并发执行如果不加以控制,可能会导致数据库中数据的不一致性。一个最常见的并发操作的例子是飞机订票系统中的订票操作。例如,在该系统中的一个活动的序列:(1)事务T1(动作1):甲售票员读出某航班的

6、机票余额A,设A=16。(2)事务T2(动作1):乙售票员读出同一航班的机票余额,A也为16。(3)事务T1(动作2):甲售票员卖出一张机票,修改机票余额A←A-1,所以A=15,把A写入数据库。(4)事务T2(动作2):乙售票员卖出两张机票,修改机票余额A←A-2,所以A=14,把A写入数据库。尚辅网http://shangfuwang.com/并发操作如果不加以控制,就可能引发下列数据的不一致性:1.丢失修改(LostUpdate)2.不可重复读(UnrepeatableRead)3.读“脏”数据(DirtyRead)尚辅网http://sh

7、angfuwang.com/1.丢失修改(LostUpdate)丢失修改是指事务T1与事务T2从数据库中读入同一数据并修改,事务T2提交的修改结果破坏了事务T1提交的修改结果,导致事务T1的修改被丢失。丢失修改的情况如图6-2所示。尚辅网http://shangfuwang.com/调度时刻事务T1事务T2t1读A=16t2读A=16t3A=A-1写回A=15t4A=A-2写回A=14(覆盖了T1对A的修改)图6-2丢失修改尚辅网http://shangfuwang.com/2.不可重复读(UnrepeatableRead)即事务T1两次读取同一

8、数据项A的内容不一致。究其原因,是在两次读操作之间,事务T2也修改了数据项A。不可重复读的情况如图6-3所示。尚辅网http://sha

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。