EF CodeFirst(三) 并发处理
悲观并发
我们先看一下不控制并发时的场景
//未进行并发处理
User user = new User { UserName="shenwei" ,certID= ""};
using (BlogContext ctx= new BlogContext())
{
ctx.Users.Add(user);
ctx.SaveChanges();
} //首先插入一条数据 并提交
//定义两个context同时进行操作
BlogContext firContext = new BlogContext ();
User u1 = firContext.Users.FirstOrDefault();
BlogContext secContext = new BlogContext ();
User u2 = secContext.Users.FirstOrDefault();
u2.UserName = "zhangxiaomao" ; //改变名字 并提交
secContext.SaveChanges();
u1.UserName = "xxxxxx" ;
u1.certID = "" ; //另一个操作改变certid,也提交
firContext.SaveChanges();

public class Blog
{
public string ID { get; set; }
public string BlogName { get; set; }
public string BlogAuthor { get; set; }
public virtual List <Post> Posts { get; set ; } //导航属性
public BlogDetails Detail { get; set; }
[ Timestamp]
public byte [] version { get; set; }
}
测试如下
//并发模拟
Blog b = new Blog
{
ID = "",
BlogName = "Gaea",
BlogAuthor = "shenwei",
Detail = new BlogDetails { }
};
//先通过一个ctx插入数据并提交
using(BlogContext context=new BlogContext())
{
context.Blogs.Add(b);
context.SaveChanges();
}
//创建一个ctx取的第一条数据,修改 但是不提交
BlogContext fircontext = new BlogContext();
Blog firstblog = fircontext.Blogs.FirstOrDefault();
firstblog.BlogName = "哈哈,被改掉了" ; //创建另一个ctx还是取第一条数据,修改并提交
BlogContext secContext = new BlogContext();
Blog secondBlog = secContext.Blogs.FirstOrDefault();
secondBlog.BlogAuthor = "JasonShen";
secContext.SaveChanges(); //这个时候再提交第一个ctx所做的修改
try
{
//这是后会发现现在的数据,已经和刚进入时发生了变化,故报错
fircontext.SaveChanges();
Console.WriteLine("保存成功" );
} catch(Exception e)
{
Console.WriteLine("保存失败" );
}
Console.ReadKey();
}




那如果捕捉到了异常,EF会怎么处理呢?使用Reload处理
Resolving optimistic concurrency exceptions with Reload
使用Reload数据作为解决乐观并发异常的策略之一,除了Reload外,还有其他几种冲突解决策略,这里只讲下常用的Reload
try
{
//这是后会发现现在的数据,已经和刚进入时发生了变化,故报错
fircontext.SaveChanges();
Console .WriteLine("保存成功" );
} catch (DbUpdateConcurrencyException e)
{
Console .WriteLine("保存失败" );
Console .WriteLine("Reload" );
e.Entries.Single().Reload();
Console .WriteLine(firstblog.BlogName); //会发现 变成了初始从数据库里加载的数据值
}
针对单个字段的并发
public class User
{
[Key ,DatabaseGenerated (DatabaseGeneratedOption .Identity)]
public Guid UserGuid { get; set; }
public string UserName { get; set; }
[ ConcurrencyCheck ]
public string certID { get; set; }
}
//针对单个字段 标示的ConcurrencyCheck 的并发
User user = new User { UserName = "shenwei" , certID = "" };
using (BlogContext ctx = new BlogContext ())
{
ctx.Users.Add(user);
ctx.SaveChanges();
} //首先插入一条数据 并提交
//定义两个context同时进行操作
BlogContext firContext = new BlogContext ();
User u1 = firContext.Users.FirstOrDefault();
BlogContext secContext = new BlogContext ();
User u2 = secContext.Users.FirstOrDefault();
u2.certID= "" ; //改变名字 并提交
secContext.SaveChanges();
try
{
u1.certID = "" ; //另一个操作改变certid,也提交
firContext.SaveChanges();
} catch (Exception e)
{
Console .WriteLine("并发报错" );
}
EF CodeFirst(三) 并发处理的更多相关文章
- 1.【使用EF Code-First方式和Fluent API来探讨EF中的关系】
原文链接:http://www.c-sharpcorner.com/UploadFile/3d39b4/relationship-in-entity-framework-using-code-firs ...
- [.NET领域驱动设计实战系列]专题一:前期准备之EF CodeFirst
一.前言 从去年已经接触领域驱动设计(Domain-Driven Design)了,当时就想自己搭建一个DDD框架,所以当时看了很多DDD方面的书,例如领域驱动模式与实战,领域驱动设计:软件核心复杂性 ...
- EF CodeFirst增删改查之‘CRUD’
最近悟出来一个道理,在这儿分享给大家:学历代表你的过去,能力代表你的现在,学习代表你的将来. 十年河东十年河西,莫欺少年穷 学无止境,精益求精 本篇旨在学习EF增删改查四大操作 上一节讲述了EF ...
- EF CodeFirst 创建数据库
最近悟出来一个道理,在这儿分享给大家:学历代表你的过去,能力代表你的现在,学习代表你的将来. 十年河东十年河西,莫欺少年穷 学无止境,精益求精 话说EF支持三种模式:Code First M ...
- 新年奉献MVC+EF(CodeFirst)+Easyui医药MIS系统
本人闲来无事就把以前用Asp.net做过的一个医药管理信息系统用mvc,ef ,easyui重新做了一下,业务逻辑简化了许多,旨在加深对mvc,ef(codefirst),easyui,AutoMap ...
- 新年奉献MVC+EF(CODEFIRST)+EASYUI医药MIS系统(转)
出处:http://www.cnblogs.com/chenlinzhi/p/4332628.html 本人闲来无事就把以前用Asp.net做过的一个医药管理信息系统用mvc,ef ,easyui重新 ...
- ASP.NET MVC深入浅出(被替换) 第一节: 结合EF的本地缓存属性来介绍【EF增删改操作】的几种形式 第三节: EF调用普通SQL语句的两类封装(ExecuteSqlCommand和SqlQuery ) 第四节: EF调用存储过程的通用写法和DBFirst模式子类调用的特有写法 第六节: EF高级属性(二) 之延迟加载、立即加载、显示加载(含导航属性) 第十节: EF的三种追踪
ASP.NET MVC深入浅出(被替换) 一. 谈情怀-ASP.NET体系 从事.Net开发以来,最先接触的Web开发框架是Asp.Net WebForm,该框架高度封装,为了隐藏Http的无状态 ...
- 第四节:EF Core的并发处理
1.说明 和EF版本的并发处理方案一致,需要知道乐观并发和悲观并发的区别,EF Core只支持乐观并发:监控并发的两种方案:监测单个字段和监测整条数据,DataAnnotations 和 Fluent ...
- EF CodeFirst简介、默认约定、数据库初始化策略
CodeFirst 工作流程 创建或修改领域类-->使用数据注解或者Fluent API来配置领域类-->使用自动数据库迁移技术或者基于代码的数据库迁移技术来创建数据库. CodeFirs ...
随机推荐
- GoLang学习之数据类型
数据类型 Go语言按类别有以下几种数据类型: bool,一个字节,值是true或者false,不可以用0或者1表示 int/uint(带符号为与不带符号位的int类型):根据平台不同是32位或者64位 ...
- isBalanced函数实现
原文:从一道面试题谈起,作者:360奇舞团 刘观宇 题目: 创建一个函数来判断给定的表达式中的大括号是否闭合,返回 true/false,对于空字符串,返回 true var expression = ...
- Django自带的后台管理样式找不到的问题。
今天发现自己用uwsgi,nginx部署完服务器后,又想用自带的Django服务器进行后台管理调试,发现Django后代管理页面样式找不到.又查看了路径发现是正确的.网上看了很多方法.最后才发现自己把 ...
- odoo开发基础--模型之基本字段类型
定义模型的时候,和python的其他框架类似,可以对比Django,同样是一个模型即:一个class对应生成数据库中的一张表, 只是odoo的继承机制比较复杂一点,在日常的开发中,定义模型的时候, 基 ...
- python解析json数据
现在的API接口多为xml或json,json解析更简洁相对xml来说 以豆瓣的API接口为例,解析返回的json数据: https://api.douban.com/v2/book/1220562 ...
- 微信应用号来了,微信小程序开发教程!
关注,QQ群,微信应用号社区 511389428,511389428 微信应用开放的服务和组件包含如下: 视图容器:视图(View).滚动视图.Swiper 基础内容:图标.文本.进度条 表单组件:按 ...
- CentOS 6.7 下 MYSQL 5.7 的安装与配置
安装 #yum源 http://dev.mysql.com/downloads/repo/yum/ #安装 rpm -Uvh http://dev.mysql.com/get/mysql57-comm ...
- Stack Overflow 2016 最新架构探秘
原文:http://nickcraver.com/blog/2016/02/17/stack-overflow-the-architecture-2016-edition/ 转载:http://www ...
- Chapter 3 Phenomenon——21
"Nobody will believe that, you know." “你知道吗没有人会相信会是这样的” His voice held an edge of derision ...
- EventProcessor与WorkPool用法--可处理多消费者
单一的生产者,消费者有多个,使用WorkerPool来管理多个消费者: RingBuffer在生产Sequencer中记录一个cursor,追踪生产者生产到的最新位置,通过WorkSequence和s ...