安徽工业大学数据库第十一章习题解答_第1页
安徽工业大学数据库第十一章习题解答_第2页
安徽工业大学数据库第十一章习题解答_第3页
安徽工业大学数据库第十一章习题解答_第4页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第十一章 并发控制1. 并发操作可能会产生哪几类数据不一致性?用什么方法能避免各种不一致性的情况。答:数据库的并发操作所带来的数据不一致性有三类:丢失更新问题、不一致性分析问题和读“脏”数据问题。对于并发操作带来的问题,通常采用并发控制的方法调度并发操作,避免造成数据的不一致性,使一个用户事务的执行不受其他事务的干扰。2. 为什么DML锁只能提供解除S封锁的操作,而不提供解除X封锁的操作。答:为防止由事务的ROLLBACK操作引起的丢失更新操作,X封锁必须保留到事务终点。即X封锁不是用UNLOCK操作解除的,而是在事务结束的语义中包含了对X封锁的解除,因此,DML不提供解除X封锁的操作。而为增加事务并发操作的程度,未到事务终点时,用户可以使用DML提供的专门解除S封锁的操作,随时解除事务的S封锁,这是因为被S封锁的数据不可能是未提交的修改。3. 为什么有些封锁需保留到事务终点,而有些封锁可随时解除。答:为防止由事务的ROLLBACK操作引起的丢失更新操作,X封锁必须保留到事务终点。而被S封锁的数据不可能是未提交的修改,因此可以随时解除事务的S封锁,达到增加事务并发操作的程度。4. 设T1、T2、T3是如下的三个事务: T1:A:=A+2; T2:A:=A*2; T3:A:=A*2( AA2 ) 设A的初值为0。 若这三个事务允许并发执行,则有多少种可能的正确结果,请一一列举出来; 请给出一个可串行化的调度,并给出执行结果; 请给出一个非串行化的调度,并给出执行结果; 若这三个事务都遵守两段锁协议,请给出一个不产生死锁的可串行化调度; 若这三个事务都遵守两段锁协议,请给出一个产生死锁的调度。解: A的最终结果可能有2、4、8、16。因为串行执行次序有T1T2T3、T1T3T2、T2T1T3、T2T3T1、T3T1T2、T3T2T1,对应的执行结果是16、8、4、2、4、2。 T1 T2 T3 Slock A Y=A=0 Unlock A Xlock A Slock A A=Y+2 等待 写回A(=2) 等待 Unlock A 等待 Y=A=2 Unlock A Xlock A Slock A A=Y*2 等待 写回A(=4) 等待 Unlock A 等待 Y=A=4 Unlock AXlock AA=Y*2写回A(=16)Unlock A最后结果A为16,是可串行化的调度。 T1 T2 T3 Slock A Y=A=0 Unlock A Slock A Y=A=0Xlock A等待 Unlock AA=Y+2 写回A(=2) Slock A Unlock A 等待Y=A=2Unlock A Xlock AXlock A等待 A=Y*2 等待 写回A(=16) 等待 Unlock A A=Y*2 写回A(=0) Unlock A 最后结果A为0,为非串行化的调度。 T1 T2 T3 Slock A Y=A=0 Xlock A A=Y+2 Slock A 写回A(=2) 等待 Unlock A 等待 Y=A=2 Xlock A Unlock A 等待 Slock A A=Y*2 等待 写回A(=4) 等待 Unlock A 等待 Y=A=4 Unlock AXlock AA=Y*2写回A(=16)Unlock AUnlock A T1 T2 T

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论