到目前为止,我一直在我的项目存储库模式和依赖注入中实现.我为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之上是完全没问题的.