EF 关于内存共享dbcontext 时发生的问题

mylogic 2016-10-10 04:02:10
我用的mysql数据库,为什么手动修改数据库内容后,数据库已经更新,但程序中查询到的数据没有变化?只有重启程序再查询才会变过来?没有用到事务。
我用下面的方式共享dbcontext
 DbContext dbContext = CallContext.GetData("myDbContext") as DbContext;
if (dbContext == null)
{
dbContext = new hisEntities();

//dbContext.Configuration.ValidateOnSaveEnabled = false;

CallContext.SetData("myDbContext", dbContext);
}
return dbContext;
...全文
548 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
mylogic 2016-10-26
  • 打赏
  • 举报
回复
谢谢诸位的建议,由于业务逻辑跨表较多,其他一些场景还会用到事务,为了方便传递实体对象,目前使用了共享的DbContext,以保证不会因为数据库上下文变动导致操作失败
mylogic 2016-10-26
  • 打赏
  • 举报
回复
引用 1 楼 D56233577 的回复:
默认情况下,EF会将之前查询出的数据存为本地数据,如果下一次查询返回了相同主键的数据,那么EF不会更新本地数据而是直接返回本地数据,从而造成和数据库不一致。 你可以使用AsNoTracking()或者每次都new一个新的DbContext来解决以上问题。
视图的查询,我用AsNoTracking()解决了新数据刷新问题,测试结果看貌似直接查表不会有这样的问题,只有视图是这样,目前还是用的共享dbContext的方式
游离失所 2016-10-11
  • 打赏
  • 举报
回复
这里共享dbcontext的方式没问题 dbcontext本来就是线程不安全的。而CallContext是为线程提供独立的数据插槽。这样下来就可以保证dbcontext'线程单例'。。 问题不是出在这块代码里
D56233577 2016-10-11
  • 打赏
  • 举报
回复
奉劝楼上说没关系的各位,别什么都想当然,拿实践来检验你说的话。
xiaoqiu_net 2016-10-11
  • 打赏
  • 举报
回复
你数据差不到最新的 和你 共享不共享DbContext没什么关系呀。? 这样线程中DbContext唯一也是没有问题的。 排除找其他的问题。
圣殿骑士18 2016-10-10
  • 打赏
  • 举报
回复
你这个问题,就是共享dbContext造成的
圣殿骑士18 2016-10-10
  • 打赏
  • 举报
回复
共享dbContext的方式是不对的,dbContext就应该用完就释放,应该作为方法内的局部变量! 我发现很多人都喜欢把dbContext全局化,是写cs程序写的比较多吧?
D56233577 2016-10-10
  • 打赏
  • 举报
回复
当然,将已有的数据分离掉或者ReLoad也是可以的,但都是繁琐的方式。建议你不要共享DbContext。
D56233577 2016-10-10
  • 打赏
  • 举报
回复
默认情况下,EF会将之前查询出的数据存为本地数据,如果下一次查询返回了相同主键的数据,那么EF不会更新本地数据而是直接返回本地数据,从而造成和数据库不一致。 你可以使用AsNoTracking()或者每次都new一个新的DbContext来解决以上问题。
“DRY——避免重复代码”是一个优秀的开发者在开发软件所具备的最重要的思想之一。我们在开发企业WEB应用程序都有一些类似的需求,例如:都需要登录页面、用户/角色管理、权限验证、数据有效性验证、多语言/本地化等等。一个高品质的大型软件都会运用一些最佳实践,例如分层体系结构、领域驱动设计、依赖注入等。我们也可能会采用ORM、数据库迁移(Database Migrations)、日志记录(Logging)等工具。 从零开始创建一个企业应用程序是一件繁琐的事,因为需要重复做很多常见的基础工作。许多公司都在开发自己的应用程序框架来重用于不同的项目,然后在框架的基础上开发一些新的功能。但并不是每个公司都有这样的实力。假如我们可以分享的更多,也许可以避免每个公司或每个项目的重复编写类似的代码。作者之所以把项目命名为“ASP.NET Boilerplate”,就是希望它能成为开发一般企业WEB应用的新起点,直接把ABP作为项目模板。 ABP的全称是Asp.net boilerplate project(asp.Net样板工程)。是github上非常活跃的一个开源项目。它并没有使用任何新的技术,只是由两名架构师将asp.net开发中常用的一些工具整合到了一起,并且部分实现了DDD的概念。是一个开箱即用的框架,可以作为asp.net分布式应用的一个良好起点。 它的功能包括: 服务器端: 基于最新的.NET技术 (目前是ASP.NET MVC 5、Web API 2、C# 5.0,在ASP.NET 5正式发布后会升级) 实现领域驱动设计(实体、仓储、领域服务、领域事件、应用服务、数据传输对象,工作单元等等) 实现分层体系结构(领域层,应用层,展现层和基础设施层) 提供了一个基础架构来开发可重用可配置的模块 集成一些最流行的开源框架/库,也许有些是你正在使用的。 提供了一个基础架构让我们很方便地使用依赖注入(使用Castle Windsor作为依赖注入的容器) 提供Repository仓储模式支持不同的ORM(已实现Entity Framework 、NHibernate、MangoDb内存数据库) 支持并实现数据库迁移(EF 的 Code first) 模块化开发(每个模块有独立的EF DbContext,可单独指定数据库) 包括一个简单的和灵活的多语言/本地化系统 包括一个 EventBus来实现服务器端全局的领域事件 统一的异常处理(应用层几乎不需要处理自己写异常处理代码) 数据有效性验证(Asp.NET MVC只能做到Action方法的参数验证,ABP实现了Application层方法的参数有效性验证) 通过Application Services自动创建Web Api层(不需要写ApiController层了) 提供基类和帮助类让我们方便地实现一些常见的任务 使用“约定优于配置原则” 客户端: Bootstrap、Less、AngularJs、jQuery、Modernizr和其他JS库: jQuery.validate、jQuery.form、jQuery.blockUI、json2等 为单页面应用程序(AngularJs、Durandaljs)和多页面应用程序(Bootstrap+Jquery)提供了项目模板。 自动创建Javascript 的代理层来更方便使用Web Api 封装一些Javascript 函数,更方便地使用ajax、消息框、通知组件、忙状态的遮罩层等等 除ABP框架项目以外,还开发了名叫“Zero”的模块,实现了以下功能: 身份验证与授权管理(通过ASP.NET Identity实现的) 用户&角色管理 系统设置存取管理(系统级、租户级、用户级,作用范围自动管理) 审计日志(自动记录每一次接口的调用者和参数) 我共享的资料包含ABP(2.02版本)的一个Demo文件以及调试候需要填的坑的处理方法(填了蛮久才填满。。。),还包括一本ABP中文教程。

17,741

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 .NET Framework
社区管理员
  • .NET Framework社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧