asp.net-mvc – 在MVC Web应用程序中的存储库中共享DbContext

栏目: 后端 · 发布时间: 6年前

内容简介:题在MVC Web应用程序中跨多个存储库共享EF DbContext的正确方法是什么?这样做是审慎/必要的,做或不做这些的陷阱是什么?背景

在MVC Web应用程序中跨多个存储库共享EF DbContext的正确方法是什么?这样做是审慎/必要的,做或不做这些的陷阱是什么?

背景

承担:

> App.MvcSite(几十个控制器,多个区域等)

> App.Services(服务层,许多服务)

> App.Data(许多存储库等)

> …等排除简单(EF Code First latest)

研究至今

我似乎在SO和互联网上至少找到了两三个思路.

>将DbContext共享/覆盖到请求,以便单个请求具有所有存储库共享的单个DbContext.

>在服务层共享/覆盖您的DbContext – 服务维护一个单一的DbContext,并根据需要将其传递到每个存储库.

>不要分享一个DbContext,因为它们很便宜,每个Repo都有自己的.

在一个小型网站上,这是一个非问题,这就是为什么大多数MS和社区示例根本就没有解决这个问题.

根据我迄今为止的经验,我没有使用有限的资料库.我一直有服务使用DbContext,并直接改变它,所以我不需要担心这一点.我被告知,从单元测试的角度来看,有限的存储库有很大的好处,我们将看看它是否能够使其余部分成为可能.

我的想法

(1) Share/scope your DbContext to the Request

这是有趣的,因为它巧妙地避免了一些开发人员认为的答案的单例上下文的缺陷,但是发现DbContext不起作用.但是它似乎有一个缺点,它假定所有的存储库,服务等将在整个请求中协调一致 – 这通常不是这样的,对吗?如果在另一个完成工作之前由一个repo保存更改. (外(内(内)))

(2) Share/scope your DbContext at the service layer

这对我来说更有意义,因为每个服务应该协调一个特定的工作单位(小写意图).因此,如果在一个请求中使用多个服务,那么每个都有自己的数据库上下文是合适的(如果不需要的话).

(3) Do not share a DbContext, since they are cheap

这是我一直做的事情,实际上我几乎总是只有一个DbContext每个请求,因为只有一个服务被调用.有时可能是两个,因为两个服务是由协调工作的控制者召集的.但是,鉴于我目前的应用程序,有许多有限的存储库,每个存储库都有自己的上下文意味着一个给定的请求可能具有3-10个DbContext实例.我假设(也许不正确)这是有问题的.

重复的问题:

在MVC Web应用程序中跨多个存储库共享EF DbContext的正确方法是什么?这样做是审慎/必要的,做或不做这些的陷阱是什么?


以上所述就是小编给大家介绍的《asp.net-mvc – 在MVC Web应用程序中的存储库中共享DbContext》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

数据挖掘导论

数据挖掘导论

Pang-Ning Tan、Michael Steinbach、Vipin Kumar / 范明、范宏建 / 人民邮电出版社 / 2010-12-10 / 69.00元

本书全面介绍了数据挖掘,涵盖了五个主题:数据、分类、关联分析、聚类和异常检测。除异常检测外,每个主题都有两章。前一章涵盖基本概念、代表性算法和评估技术,而后一章讨论高级概念和算法。这样读者在透彻地理解数据挖掘的基础的同时,还能够了解更多重要的高级主题。 本书是明尼苏达大学和密歇根州立大学数据挖掘课程的教材,由于独具特色,正式出版之前就已经被斯坦福大学、得克萨斯大学奥斯汀分校等众多名校采用。 ......一起来看看 《数据挖掘导论》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

URL 编码/解码
URL 编码/解码

URL 编码/解码

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具