当前位置 : 主页 > 网络编程 > ASP >

asp.net-mvc – 使用实体框架的没有存储库模式的依赖注入

来源:互联网 收集:自由互联 发布时间:2021-06-24
到目前为止,我一直在我的项目存储库模式和依赖注入中实现.我为ORM使用Entity Framework,并且还有一个管理我的存储库的服务层. 我有点想做一些对手头的问题不那么重要的事情.我不太可能
到目前为止,我一直在我的项目存储库模式和依赖注入中实现.我为ORM使用Entity Framework,并且还有一个管理我的存储库的服务层.

我有点想做一些对手头的问题不那么重要的事情.我不太可能更改我的数据库或ORM.对于小型项目,我不需要实施测试.

但我喜欢每次获取数据时都不向数据库发送请求的想法,如果它已经在内存中从那里获取数据.

我的问题是:如果我在Asp.Net MVC应用程序中使用Entiry Framework,而不是使用存储库模式,但仍然在EF的DBContext上使用DI,我可以通过防止往返数据库服务器进行读取来获得性能的好处吗?

通过在DbContext上实现DI,我的意思是Ninject示例:

kernel.Bind<MyDBContext>().ToSelf().InRequestScope();

谢谢

在EF DbContext之上添加存储库模式对性能优化没有帮助.

DbContext是一个工作单元,用于跟踪加载/更改/添加的实体. IDbSet< T>基本上是一个存储库.所以DbContext有一个存储库列表. DbContext负责执行一些性能优化,例如不加载相同的实体两次,而是在通过id加载两次时返回相同的实例.
当然,要应用此功能,必须重用相同的DbContext实例.如果您创建两个DbContext实例,它们将加载同一个实体一次.

所以使用

kernel.Bind<MyDBContext>().ToSelf().InRequestScope();

而不是将自己的“存储库模式”置于MyDBContext之上是完全没问题的.

网友评论