第11章 数据库并发控制及SQLSERVER的并发控制机制ppt课件.ppt

第11章 数据库并发控制及SQLSERVER的并发控制机制ppt课件.ppt

ID:58714207

大小:372.50 KB

页数:117页

时间:2020-10-04

第11章 数据库并发控制及SQLSERVER的并发控制机制ppt课件.ppt_第1页
第11章 数据库并发控制及SQLSERVER的并发控制机制ppt课件.ppt_第2页
第11章 数据库并发控制及SQLSERVER的并发控制机制ppt课件.ppt_第3页
第11章 数据库并发控制及SQLSERVER的并发控制机制ppt课件.ppt_第4页
第11章 数据库并发控制及SQLSERVER的并发控制机制ppt课件.ppt_第5页
资源描述:

《第11章 数据库并发控制及SQLSERVER的并发控制机制ppt课件.ppt》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、数据库原理及应用PrinciplesandApplicationofDatabase第十一章数据库并发控制及SQLServer的并发控制机制飞机定票系统银行数据库系统为何要并发?并发执行可能引起哪些问题?如何知道并发执行后结果是正确的?并发执行如何控制实现?第十一章数据库并发控制及SQLServer的并发控制机制11.1并发控制概述11.2并发调度的可串行性11.3封锁11.4两段锁协议11.5封锁的粒度11.6活锁和死锁11.7SQLServer的并发控制机制11.8小结多事务执行方式事务串行执行每个时刻只有一个事务运行,其他事务必须等到这个事务结束以后方能运

2、行不能充分利用系统资源,发挥数据库共享资源的特点T1T2T3多事务执行方式(续)交叉并发方式(interleavedconcurrency)事务的并行执行是这些并行事务的并行操作轮流交叉运行单处理机系统中的并发方式,能够减少处理机的空闲时间,提高系统的效率T1T2T3T1T2T1T3T3T2T2T1多事务执行方式(续)同时并发方式(simultaneousconcurrency)多处理机系统中,每个处理机可以运行一个事务,多个处理机可以同时运行多个事务,实现多个事务真正的并行运行。事务并发执行带来的问题可能会存取和存储不正确的数据,破坏事务的隔离性和数据库的一致

3、性DBMS必须提供并发控制机制并发控制机制是衡量一个DBMS性能的重要标志之一并发控制机制的目的改善系统的性能,交叉利用系统资源改善短事务的响应时间(1)甲售票点(甲事务)读出某航班的机票余额A,设A=16。 (2)乙售票点(乙事务)读出同一航班的机票余额A,也为16。 (3)甲售票点卖出一张机票,修改余额AA-1,所以A为15,把A写回数据库。 (4)乙售票点卖出一张机票,修改余额AA-1,所以A为15,把A写回数据库。数据不一致实例:飞机订票系统原因:并发操作破坏了事务的隔离性。数据不一致实例:飞机订票系统并发操作带来的数据不一致性丢失修改(los

4、tupdate)读“脏”数据(dirtyread)不可重复读(non-repeatableread)丢失修改TimeT1T2A=16读A=16读A=16A=A-1写回AA=15A=A-1写回AA=15A=15AnIntroductiontoDatabaseSystem丢失修改(续)丢失修改是指事务1与事务2从数据库中读入同一数据并修改事务2的提交结果破坏了事务1提交的结果导致事务1的修改被丢失丢失修改(续)原因:两个(或多个)事务对“同一数据”并发地“写入”引起(违背了事务的隔离性,事务间产生了干扰)称为“写-写”冲突。结果:与串行地执行两个(或多个)事务的结果

5、不一致。读“脏”数据TimeT1T2C=100读C=100C=C*2写回CC=200C=100读C=200RollbackAnIntroductiontoDatabaseSystem读“脏”数据事务1修改某一数据,并将其写回磁盘事务2读取同一数据后,事务1由于某种原因被撤消,这时事务1已修改过的数据恢复原值事务2读到的数据就与数据库中的数据不一致,是不正确的数据,又称为“脏”数据。读“脏”数据原因:由一事务读另一事务尚未提交的数据引起称为“写-读”冲突结果:有可能读到要回退的更新数据不可重复读TimeT1T2A=50B=100读A=50读B=100A+B=150

6、读B=100A=50B=200B=B*2写回B读A=50读B=200A+B=250AnIntroductiontoDatabaseSystem不可重复读事务1读取数据后,事务2执行更新操作,使事务1无法再现前一次读取结果。不可重复读原因:由“读-写”冲突引起结果:第二次读的值与前次读的值不同三类不可重复读事务1读取某一数据后:事务2对其做了修改,当事务1再次读该数据时,得到与前一次不同的值。事务2删除了其中部分记录,当事务1再次读取数据时,发现某些记录神密地消失了。事务2插入了一些记录,当事务1再次按相同条件读取数据时,发现多了一些记录。后两种不可重复读有时也称

7、为幻影现象(phantomrow)不可重复读----幻影现象TimeT1T2Selectcount(*)whereSsex=‘女’2rowsreturnedInsert刘晨,女王敏,女李丽,女刘晨,女王敏,女李丽,女Selectcount(*)whereSsex=‘女’3rowsreturnedAnIntroductiontoDatabaseSystem结论:不同事务中对同一对象进行“写-写”、“写-读”或“读-写”的操作进行交错,都会造成冲突。对事务的并发执行的控制,归结为对“数据访问冲突”的控制。AnIntroductiontoDatabaseSystem第

8、十一章数据库并发控制及S

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

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

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