c#

位置:IT落伍者 >> c# >> 浏览文章

ADO.NET Entity Framework 试水——并发[1]


发布日期:2022年04月20日
 
ADO.NET Entity Framework 试水——并发[1]

提到数据库操作特别是企业级的数据库应用就不得不提一个多人操作时经常会产生的问题——并发沖突本文首先来看一下什么是并发沖突传统的并发沖突有现有的处理方式最后结合EF看一个处理并发沖突的实例

要完成本文中的实例您需要作如下准备

将Visual Studio NET Framework 升级到SP点击转到升级地址

安装SQL SERVER VS 中自带的EXPRESS版的SQL SERVER应该也可以用

载并附加数据库点击下载DemoDbV

创建一个VB Console Application并且取一个合适的名字(例如Concurrency之类的)注意目标Framework要设置成

什么是并发沖突

让我们来看一个跟取款相关的例子某年某月某日某时某分老王在A取款机取钱他儿子小王同时在B取款机取钱(不要问我为什么这么巧^_^)他俩从同一个账号上取于是就发生了如下一序列的操作

A取款机向中央数据库提问这账上还有多少钱?

B取款机向中央数据库询问这账上还有多少钱?

中央数据库回答A取款机W

中央数据库回答B取款机W

然后老王对A取款机说我要取出W

同时小王对B取款机说我要取出W

A取款机就算了一下WW=W>于是就吐出W现金给了老王并且准备告诉中央数据库现在还剩W啦但是就在它告诉中央数据库之前发生了以下的事情

B取款机计算了一下W(此时它还不知道余额已经成W了因为A取款机还没有告诉中央数据库)减去W等于W大于于是就吐出W现金给了小王然后它当然也要知会中央数据库

中央数据库于是收到A取款机的消息这个账号还剩W于是刷新余额为W然后又收到B取款机说还剩W于是就刷新余额为W

呵呵于是小王+老王的账户里一共存有W元结果老王取了W元小王取了W元账户里却还剩了W元!

这就是一种并发沖突由于同一时间有两个或者多个端在对同一数据进行操作从而导致数据发生了错误如果取款机真的以这样的方式来处理并发那么我现在就不写这片文章了——赶紧发动全家对表说好了在某一时刻同时取钱去

常见的并发沖突处理方式

一般来说我们把并发沖突处理方式归结为

第一类放任不管方式第二类开放式并发处理方式第三类保守式并发处理方式

[] [] [] []

               

上一篇:ADO.NET Entity Framework 试水——并发[3]

下一篇:ADO.NET Entity Framework 试水——并发[2]