该文档转载自下面地址

http://dotnet.chinaitlab.com/ADONET/764079.html

摘录如下

二、什么是并发冲突
  让我们来看一个跟取款相关的例子:某年某月某日某时某分,老王在A取款机取钱,他儿子小王同时在B取款机取钱(不要问我为什么这么巧^_^),他俩从同一个账号上取。于是就发生了如下一序列的操作:
  A取款机向中央数据库提问:这账上还有多少钱?
  B取款机向中央数据库询问:这账上还有多少钱?
  中央数据库回答A取款机:2W。
  中央数据库回答B取款机:2W。
  然后,老王对A取款机说:我要取出1.5W。
  同时,小王对B取款机说:我要取出1.8W。
  A取款机就算了一下,2W-1.5W=0.5W>0,于是就吐出1.5W现金给了老王,并且准备告诉中央数据库,现在还剩0.5W啦。但是,就在它告诉中央数据库之前,发生了以下的事情:
  B取款机计算了一下,2W(此时,它还不知道余额已经成0.5W了,因为A取款机还没有告诉中央数据库)减去1.8W等于0.2W大于0,于是就吐出1.8W现金给了小王。然后,它当然也要知会中央数据库。
  中央数据库于是收到A取款机的消息,说,这个账号还剩0.5W,于是刷新余额为0.5W。然后又收到B取款机说还剩0.2W,于是,就刷新余额为0.2W。
  呵呵,于是,小王+老王的账户里一共存有2W元,结果老王取了1.5W元,小王取了1.8W元,账户里却还剩了0.2W元!~@#$%^&
  这就是一种并发冲突,由于同一时间有两个或者多个端在对同一数据进行操作,从而导致数据发生了错误。如果取款机真的以这样的方式来处理并发,那么,我现在就不写这片文章了——赶紧发动全家对表,说好了在某一时刻同时取钱去^_^

这个例子举得很不错

三、常见的并发冲突处理方式
  一般来说,我们把并发冲突处理方式归结为3类。
  第一类:放任不管方式;第二类:开放式并发处理方式;第三类:保守式并发处理方式。
  1. 放任不管方式:
  与其说这是一种处理并发冲突的方式,不如说,它是一种没有对并发冲突做任何处理的方式。但是在许多过去的系统里,由于没有考虑到多用户、网络应用等情况,这种"处理方式"还真存在于不少系统中。
  举例来说,A、B两人从数据库中获取了同一个笔记本的信息,例如:IBM ThinkPad T61吧。然后:A把牌子改成了:Lenovo ThinkPad,B把型号改成了T61 8890A24。然后,他们开始提交了。此时,如果A先提交,然后B提交,那么,最后的结果是:IBM ThinkPad T61 8890A24;反之,则变成Lenovo ThinkPad T61。
  总之一句话,谁最后提交谁老大。想像一下,如果A修改了1000个属性的值,B修改了1个属性的值,那么,对于先提交的A来说,这将是一个多么惨痛的打击:-)
  虽然这种放任不管的方式似乎不太负责任,但是,其处理性能却是相对较高的。
  2. 开放式并发处理
  开放式并发处理,老外叫做Optimistic Concurrency——乐观的并发。这种并发处理方式要求我们对并发抱有一种乐观的态度:百分之九十九点九九不会发生并发冲突,万一发生了,系统也能捕获到冲突,或者根据策略自动处理,或者,就提醒一下用户,让用户来决定是不是要继续提交。
  仍然用上面的例子来说这事儿:A、B两个人同时获取了笔记本的信息:IBM ThinkPad T61。然后……(此处跟上例做一样的修改,直到提交)此时,如果A先提交,那么,B提交的时候,系统会发现,哎哟,不好,有并发冲突了,就会抛个异常给B,让B知道,发生并发冲突了,然后,B就可以根据实际情况,选择相应的处理策略(比如,继续提交进行覆盖或者取消提交等等);相反,如果B先提交,那么,A提交时,就会得到相应的提醒。
  这样的并发处理方式,可以说在可靠性与性能上取得平衡,适合于对数据可靠性要求不是特别严格,需要较高的性能,并且不会大量发生并发的场合。
  3. 保守式并发处理
  这是最为严谨的一种并发冲突的处理方式。它把并发转化为了串行操作。
  例如,A从数据库中获取了笔记本信息:IBM ThinkPad T61,B也要对其进行修改,但此时由于A已经从数据库中将数据取出,因此,B被置于等待状态。直到A把数据修改完提交了,数据库数据更新为Lenovo ThinkPad T61了,此时,数据库才把数据给B,那么B就可以在Lenovo ThinkPad T61的基础上,把它修改为Lenovo ThinkPad T61 8890A24。而在B提交前,其它一切针对此记录的操作都得排除等着B。
  这样子当然非常理想,由于不存在并发,自然也就消除了并发冲突的问题。但是,这种锁也存在着较为隐蔽的风险:如果A修改了数据,一直不提交,或者A因为故障,没有办法提交,那么,其它所有的相关的操作,都将被阻碍住。因此,只有对数据准确性要求极高并且用户可以忍受等待的情况下,使用这种并发冲突的处理方法。

EF发布时,提供了两种并发冲突处理方式:放任不管方式和开放式并发。默认采用放任不管的方式处理。
  如果要使用开放式并发,那么,必须设置相应属性上的Concurrency Mode值为Fixed。我们先对实体类的属性进行修改,让其支持开放式并发,然后来模拟一个并发的序列,看看怎么来处理并发冲突

转载于:https://www.cnblogs.com/chenxizhang/archive/2008/11/05/1326855.html

ADO.NET Entity Framework中的并发控制 【转载】相关推荐

  1. 软件开发知识--[ADO.NET Entity Framework]

    ADO.NET Entity Framework 是微软以 ADO.NET 为基础所发展出来的对象关系对应 (O/R Mapping) 解决方案,早期被称为 ObjectSpace,现已经包含在 Vi ...

  2. Entity Framework (EF)/Linq To entity/ ESQL(entity sql)区别 ADO.NET Entity Framework:来自微软官方的ORM框架

    长久以来,程序员和数据库总是保持着一种微妙的关系,在商用应用程序中,数据库一定是不可或缺的元件,这让程序员一定要为了连接与访问数据库而去学习 SQL 指令,至少对于我而言,我觉得这是一个很不爽的事情. ...

  3. EF(ADO.NET Entity Framework)

    对象/关系映射框架 ADO.NET Entity Framework 是微软以 ADO.NET 为基础所发展出来的对象关系对应 (O/R Mapping) 解决方案.该框架曾经为.NET Framew ...

  4. 如何解决ado.net entity framework的使用,再别的调用项目中依然正常

    ado.net entity framework,在生产实体模型后.会生成一长串的connectionstring.如果此时你又新建了一个project,去调用原先放实体模型的project中的实体模 ...

  5. 转载:ADO.NET Entity Framework 试水系列索引(2008/9/9更新,本系列结束)

    Visual Studio 2008发布时,微软给我们带来了LinQ to SQL,解决所谓"阻抗不匹配"问题.最近,随着Visual Studio 2008 SP1的正式发布,又 ...

  6. ADO.NET Entity Framework 学习(1) [ZT]

    前一段时间园子里有很多文章介绍分析了Linq To SQL,它可以说是一个简单实现的ORM,是微软针对数据和对象的阻抗不平衡的问题.C# 3.0推出一些新的特性,比如Extension Method, ...

  7. ADO.NET Entity Framework 简介

    一直对EF都是一知半解的,没有系统的了解过EF有什么样的功能,有什么具体的好处.在接下来的文章中会详细介绍EF.以下是参考MSDN上的文章,翻译并加以自己的理解得出的. ADO.NET Entity  ...

  8. 一处 ADO.NET Entity Framework 的逻辑BUG

    这几天开始接触ADO.NET Entity Framework,突然发现一处奇怪的BUG. 首先来看这样一个目录结构: 我将EDM模型存入了一个名为"A"的目录中,然后编辑模型,设 ...

  9. 在Entity Framework中使用存储过程(一):实现存储过程的自动映射

    之前给自己放了一个比较长的假期,在这期间基本上没怎么来园子逛.很多朋友的留言也没有一一回复,在这里先向大家道个歉.最近一段时间的工作任务是如何将ADO.NET Entity Framework 4.0 ...

  10. ADO.NET Entity Framework Beta2(五)/快速入门(实体框架)

    This quickstart illustrates a series of tasks that support the topics in Getting Started with the En ...

最新文章

  1. zabbix安装--LAMP环境下
  2. 怎样学好python-怎样学好python
  3. 前端学PHP之面向对象系列第四篇——关键字
  4. 【数学建模】MATLAB应用实战系列(九十二)-教你怎么挑对象,层次分析法应用案例(附MATLAB代码)
  5. 挑战 10 个最难回答的 Java 问题(附答案)
  6. Oracle创建表,并添加默认值和备注
  7. 二叉树的中序遍历非递归方法(算法导论第三版12.1-3)
  8. C#快速导入海量XML数据至SQL Server数据库
  9. 当年发明hello, world的大神,后来怎么样了?
  10. Verilog状态机的编写学习
  11. linux以长格式显示当前目录的详细信息,Linux常用命令系列——文件和目录操作命令(ls)...
  12. python 分组箱线图_Python数据科学实践 | 绘图模块4
  13. 流媒体技术学习笔记之(七)进阶教程OBS参数与清晰度流畅度的关系
  14. MATLAB之fprintf
  15. php怎样做艺术字体,用ps打造科幻艺术字体
  16. 使用USB充电的5号电池
  17. 矩阵理论复习(十二)
  18. html字两边的横线_css实现中间文字两边横线效果
  19. 统计学专业综合【个人笔记】
  20. Transact-SQL变量基本语法

热门文章

  1. 想成长为一名年薪50万+的实战型架构师?必掌握这7大实战技能经验
  2. 设置windows服务依赖项
  3. [Tyvj 模拟赛] 运
  4. HTML5本地存储——IndexedDB二:索引
  5. Java基础知识强化54:经典排序之插入排序(InsertSort)
  6. 单文档切换OpenGL视图
  7. 计算给定坐标系和各个定点坐标的凸多边形的面积
  8. Dot net GC
  9. MSSQL数据库管理---索引
  10. 解决Secure Shell Client(SSH)客户端中文乱码的方法