数据库并发控制及SQLSERVER的并发控制机制

数据库并发控制及SQLSERVER的并发控制机制

ID:39711810

大小:333.52 KB

页数:117页

时间:2019-07-09

数据库并发控制及SQLSERVER的并发控制机制_第1页
数据库并发控制及SQLSERVER的并发控制机制_第2页
数据库并发控制及SQLSERVER的并发控制机制_第3页
数据库并发控制及SQLSERVER的并发控制机制_第4页
数据库并发控制及SQLSERVER的并发控制机制_第5页
资源描述:

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

1、数据库原理及应用PrinciplesandApplicationofDatabase第十一章数据库并发控制及SQLServer的并发控制机制PrinciplesandApplicationofDatabase飞机定票系统PrinciplesandApplicationofDatabase银行数据库系统PrinciplesandApplicationofDatabase为何要并发?并发执行可能引起哪些问题?如何知道并发执行后结果是正确的?并发执行如何控制实现?PrinciplesandApplicationofDatabase第十一章数

2、据库并发控制及SQLServer的并发控制机制11.1并发控制概述11.2并发调度的可串行性11.3封锁11.4两段锁协议11.5封锁的粒度11.6活锁和死锁11.7SQLServer的并发控制机制11.8小结PrinciplesandApplicationofDatabase多事务执行方式事务串行执行每个时刻只有一个事务运行,其他事务必须等到这个事务结束以后方能运行不能充分利用系统资源,发挥数据库共享资源的特点T1T2T3PrinciplesandApplicationofDatabase多事务执行方式(续)交叉并发方式(inter

3、leavedconcurrency)事务的并行执行是这些并行事务的并行操作轮流交叉运行单处理机系统中的并发方式,能够减少处理机的空闲时间,提高系统的效率T1T2T3T1T2T1T3T3T2T2T1PrinciplesandApplicationofDatabase多事务执行方式(续)同时并发方式(simultaneousconcurrency)多处理机系统中,每个处理机可以运行一个事务,多个处理机可以同时运行多个事务,实现多个事务真正的并行运行。PrinciplesandApplicationofDatabase事务并发执行带来的问题

4、可能会存取和存储不正确的数据,破坏事务的隔离性和数据库的一致性DBMS必须提供并发控制机制并发控制机制是衡量一个DBMS性能的重要标志之一PrinciplesandApplicationofDatabase并发控制机制的目的改善系统的性能,交叉利用系统资源改善短事务的响应时间PrinciplesandApplicationofDatabase(1)甲售票点(甲事务)读出某航班的机票余额A,设A=16。 (2)乙售票点(乙事务)读出同一航班的机票余额A,也为16。 (3)甲售票点卖出一张机票,修改余额AA-1,所以A为15,把A写

5、回数据库。 (4)乙售票点卖出一张机票,修改余额AA-1,所以A为15,把A写回数据库。数据不一致实例:飞机订票系统PrinciplesandApplicationofDatabase原因:并发操作破坏了事务的隔离性。数据不一致实例:飞机订票系统PrinciplesandApplicationofDatabase并发操作带来的数据不一致性丢失修改(lostupdate)读“脏”数据(dirtyread)不可重复读(non-repeatableread)PrinciplesandApplicationofDatabase丢失修改Ti

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

7、PrinciplesandApplicationofDatabase读“脏”数据TimeT1T2C=100读C=100C=C*2写回CC=200C=100读C=200RollbackPrinciplesandApplicationofDatabase读“脏”数据事务1修改某一数据,并将其写回磁盘事务2读取同一数据后,事务1由于某种原因被撤消,这时事务1已修改过的数据恢复原值事务2读到的数据就与数据库中的数据不一致,是不正确的数据,又称为“脏”数据。PrinciplesandApplicationofDatabase读“脏”数据原因:由

8、一事务读另一事务尚未提交的数据引起称为“写-读”冲突结果:有可能读到要回退的更新数据PrinciplesandApplicationofDatabase不可重复读TimeT1T2A=50B=100读A=50读B=100A

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

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

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