- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个使用纯色图案的 Visual Studio 解决方案。我有一个 IRepository(Crud 实现)、IDbFactory(由存储库使用)、IUnitOfWork。我也有服务,他们使用存储库来构建自定义查询和复杂的数据库操作。我也在 Ninject 中使用 IoC 模式。在 web mvc Controller 中,我只使用服务来访问数据库。存储库接收构建 EntityFramework 上下文的 IDbFactory。我有一些问题:
我的项目结构有问题吗?这是我必须在存储库层修复的东西吗?我该怎么办?该项目处于开发阶段,因此我可以更改数据访问架构。我喜欢在 Controller 中使用 IQueryables,这样用户在数据网格中的过滤器就会产生 sql 查询。
最佳答案
好吧,就您在这里陈述的问题而言,您的项目结构没有任何问题。问题源于使用 Singleton 作用域。您应该为 Web 应用程序使用 Request 范围。这可确保您获得每个请求的新上下文,因此不同请求甚至不同客户端之间不会出现重叠,这可能非常危险。
也就是说,您的项目结构设计过度。存储库/工作单元模式旨在用于低级数据访问。 ORM,如 Entity Framework ,处理所有这些,事实上, Entity Framework 已经实现了这些模式。 DbContext
是工作单元,每个 DbSet
都是一个存储库。在此之上添加您自己的存储库/工作单元层是多余且不必要的。您的服务应该直接使用您的 Entity Framework 上下文。即便如此,拥有多个服务也可能是不必要的,这取决于它们的作用。如果它们都使用相同的数据源(即 Entity Framework 上下文),特别是如果它们都使用相同 Entity Framework 上下文,那么它们真的应该全部整合为一个。
在我自己的个人项目中,我使用一个“服务”类,每个唯一的上下文实例都有通用方法。通用方法让我可以使用属于该上下文的任何实体,而无需新建“服务”类的其他实例。通过确保一切都实现一个或多个接口(interface)并使用依赖注入(inject)来满足接口(interface)约束,底层数据层被完全分解出来。我有一个 series of posts如果您有兴趣,那会更详细。
我说这一切是因为您似乎过分关注模式和“最佳实践”。这些只是指南。它们就像自行车上的训练轮。它们都基于良好代码设计的各种原则。学习并应用原则,不要担心选中某种设计模式列表中的所有框。
有趣的是,Stack Overflow 的核心代码库实际上避开了一些模式(甚至是依赖注入(inject)),因为它们非常专注于原始性能,而一些设计模式在应用时实际上会阻碍性能。关键是应用程序的设计方式应基于特定应用程序的需求。设计模式应仅在符合您的应用程序需求的情况下应用,而不仅仅是因为您认为您应该这样做。
关于.net - Asp Net Mvc 中的 SOLID 原理、Repository 模式和 EntityFramework 缓存,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41769475/
全部: 我们使用 ASP.NET Web 窗体开始了我们的项目。 我们的 ASP.NET C# web 应用程序在以下环境中使用 .NET Framework 4 ASP.NET Web Forms.
我在尝试为 Entity Framework Core 添加迁移到 Code First 项目时遇到错误,这里是详细信息... 我创建了一个新的 ASP.Net Core Web 项目(VS 2017
Error 1 Copying file bin\EntityFramework.SqlServer.xml to obj\Debug\Package\PackageTmp\bin\Entit
我有一个WPF应用程序,我使用了MVVM体系结构,数据库sql server compact 4。 首先是Entityframework.sqlserverCompact数据库,我使用了通用存储库模式
例如,将 products.Where(p => p.LastModifiedOn > someDate) 总是以相同的订单返回产品(无论如何订购,只要每次调用相同的代码时都是一致的)?或者我应该添加
好吧,假设我有一个用户表,然后是一个记录所有登录尝试的表(Id(计数器)、userId、时间以及是否成功) 现在在我的实体模型中,我希望它成为 2 个关联的一个,包含所有成功尝试的时间和一个包含所有不
我正在努力处理如何最好地跨多个 Visual Studio 项目分解域模型。我正在使用 EntityFramework 4 和企业类型模式来合理化一个可以重用于各种应用程序的系统。最终我想得到一组可以
是否可以使用 POCO 和 EF 处理以下情况?我想要一个 Vehicles 表,有一些 bool 字段,如 IsFast、IsVan、IsTruck,然后有一个 Vehicles 类,有一个 Fas
当我通过传递比较泛型类型 TId 的谓词调用 DbSet.FirstOrDefault() 时,出现以下异常: unable to create a constant value of type 's
我正在使用 EF5 将一些数据从一个数据库迁移到另一个数据库。我通常会使用 SQL 来做这样的事情,但是我需要其他功能(比如在 MembershipProvider 中创建用户)并且希望在 EF 中完
我创建了一个单独的项目并将我的模型复制到这个项目中。我引用了 using System.ComponentModel.DataAnnotations 我的模型定义如下: public class F
上下文: 我有两个类在 SQL 中有两个对应的表。 系统信息 EF 版本: SQL 版本:2012 类 public class Employee { public Employee(
我有一个定义了主从关系的 Entity Framework 对象。详细信息对象集合有一个导航属性。 在稍后的代码中,我尝试使用 AutoMapper 将其中一个主对象映射到数据传输对象。但是,数据传输
有没有办法让这个通用 Context.SalesEntity.Where(t=>t.id==3).Delete(); 有点像 private void DoWork(Expression> predi
来自 NHibernate 背景 - 我有一些审计列来反射(reflect)谁最后编辑了一条记录,以及该编辑发生的时间。 我已经覆盖了 SaveChanges 以寻找一个公共(public)基类,并使
我是 EntityFramework 6 的新手,一直在 POCO 中遇到问题。 以下是我的代码 Domain.cs public abstract class BaseEntity { [K
我刚在单元测试项目中遇到一个问题,坚持认为它需要 EntityFramework 的引用,我确信它不需要它。其他项目正在引用单元测试项目正在引用/测试的项目/扩展方法,并且在不引用 EntityFra
下面的代码应该做什么?在此代码中添加包含表的目的是什么,它应该对与 PersonId 相关的 JobType 进行级联删除,还是只删除具有指定 PersonId 的 Person ? db.tblPe
我试图了解延迟加载在 Entity Framework 6 中是如何工作的。在我看来,延迟加载只适用于 DbContext,其中“to-be-loaded”属性已经存在访问过。请查看下面的示例 - 测
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Entity Framework Validation EntityFramework有什么好的灵活的验证框
我是一名优秀的程序员,十分优秀!