数据库原理补充:数据库并发控制软件设计案例.ppt
《数据库原理补充:数据库并发控制软件设计案例.ppt》由会员分享,可在线阅读,更多相关《数据库原理补充:数据库并发控制软件设计案例.ppt(24页珍藏版)》请在三一办公上搜索。
1、,并发控制案例分析,主讲:吕震宇,说明,实验环境:Visual Studio.NET 2005SQL Server 2005其它说明:SQL Server 2000+VS.NET 2003 也可以需要对代码做细微调整源代码及数据库见附件,并发控制案例,设某银行存款帐户数据如下表:现在要求编写一程序,完成两项功能:存款与取款。每次操作完成后向明细表中插入一行记录并更新帐户余额。,1、问题似乎很简单,解决办法:读取最后一行记录的帐户余额数据 根据存、取款金额计算出新的帐户余额 将新的记录插入表中真的这么简单?在不考虑并发问题的情况下是可行的如果考虑并发,问题就多了,到银行取钱,单位发工资,银行读取
2、帐户 余额400元,单位读取帐户 余额400元,单位发工资 2000元 更新帐户余额,取款100元 更新帐户余额,余额错误,上述解决办法的并发问题,2、让我来想一想,问题所在:并发问题!解决办法:加锁!在读最后一条记录时先加上锁。怎么加锁?加什么锁?读之前加共享锁?读之前加排它锁?,读之前加共享锁?显然不行!,到银行取钱,单位发工资,银行读取帐户 余额400元,单位读取帐户 余额400元,单位发工资 2000元 更新帐户余额,取款100元 更新帐户余额,余额错误,读之前加排它锁,事务完成再释放?三级封锁协议中没有定义读前加排它锁(暂且不管)显然不行!,到银行取钱,单位发工资,银行读取帐户 余额
3、400元,单位读取帐户 余额400元,单位发工资 2000元 更新帐户余额,取款100元 更新帐户余额,余额错误,等待 等待 等待,还不止这些,如何读取帐户余额?SELECT TOP 1 帐户余额 FROM 帐户明细ORDER BY 序号 DESC存在的问题:在并发场景下你怎么确定它一定是最后一行?随着数据量增大越来越没效率(因为需要排序),3、看来问题真的不是这么简单,问题出在哪里呢?从系统设计一开始我们就走错了!重新设计!,Account,AccountDetail,冗余数据,为什么引入冗余数据?确保帐户余额在唯一的地方进行存储避免了读取帐户余额时访问大量数据并排序新问题:我们无法直接对数
4、据库进行锁操作必须通过合理的事务隔离级别完成并发控制ReadUnCommittedReadCommittedRepeatableReadSerializable,4、着急吃不着热豆腐,看来我们必须对各事务隔离级别逐一分析 ReadUnCommitted显然不行在这个事务隔离级别下连脏数据都可能读到,何况“脏”帐户余额数据。ReadCommitted也不行该隔离级别与二级封锁协议相对应。读数据前加共享锁,读完就释放。前面分析过,此处不再赘述。,RepeatableRead这个隔离级别比较迷惑人,需要仔细分析:RepeatableRead对应第三级封锁协议:读前加共享锁,事务完成才释放。例:假设事
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据库 原理 补充 并发 控制 软件设计 案例
链接地址:https://www.31ppt.com/p-5985532.html