- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我们正在处理的这个项目中使用 .net C# 4.0、VS 2010、EF 4.1 和遗留代码。
我正在开发一个 win 表单项目,我决定开始使用 Entity Framework 4.1 来访问 ms sql 数据库。代码库很旧,我们有一个使用数据适配器的现有数据层。这些数据适配器到处都在使用(在 Web 应用程序和 Win Form 应用程序中)我的计划是随着时间的推移用 EF 替换旧的数据库访问代码,并摆脱 UI 层和数据层之间的紧密耦合。
因此,我的想法是或多或少地将 EF 与遗留数据访问层相结合,并使用 EF 以更现代的方式慢慢取代遗留数据层。所以现在我们需要同时使用 EF 和遗留数据库访问代码。
到目前为止,我所做的是添加一个包含 edmx 文件和上下文的项目。 edmx 是使用数据库优先方法生成的。我还添加了另一个包含 POCO 类的项目(通过使用 ADO.NET POCO 实体生成器)。我或多或少地遵循了 Julia Lerman 在她的“Programming Entity Framework”一书中关于如何拆分模型和生成的 POCO 类的方法。数据库模型已经设置多年,更改表和关系、触发器、存储过程等不是一个选项,所以我基本上坚持使用数据库模型。
我已经阅读了有关存储库模式和工作单元的内容,我有点喜欢这些模式,但是当我同时需要处理 EF 和遗留数据库访问代码时,我很难实现它们。特别是当我没有时间用纯 EF 实现替换所有遗留数据库访问代码时。在一个完美的世界中,我会使用全新的数据模型重新开始,但这不是一个选项。
这里是存储库和工作单元模式吗?为了在我的业务层中使用 POCO 类,有时我需要同时使用 EF 和遗留数据库代码来填充我的 POCO 类。换句话说,有时我可以使用 EF 检索我需要的一部分数据,并使用旧的数据库访问层检索其余数据,然后将数据映射到我的 POCO 类。当我想更新一些数据时,我需要从 POCO 类中选取数据并使用遗留数据访问代码将数据存储在数据库中。因此,当我想在 UI 中显示数据时,我需要将从遗留数据访问层检索到的数据映射到我的 POCO 类,反之亦然,当我想将数据保存到数据库时。
为了使事情复杂化,我们将一些数据存储在我们在运行前不知道其名称的表中(请不要问我为什么:-))。因此,在旧的数据库访问层中,我们必须根据其他表的信息在插入表名和列名的位置动态创建 sql 语句。
我还发现 POCO 类之间的关系有点过于以数据库为中心。换句话说,我觉得我需要有一个更简化的领域模型来使用。也许我应该创建一个符合要求的域模型,然后将 POCO 类用作“DAO”来填充域模型类?
您将如何使用存储库模式和工作单元模式来实现它? (如果这是要走的路)
最佳答案
警钟在为我敲响!我们不久前尝试做类似的事情(仅使用 nHibernate 而不是 EF4)。我们在与 ORM 一起运行 ADO.NET 时遇到了几个问题——数据库并发性是一个大问题。
The database model has been set for years and it's not an option the change the table and the relationships, triggers, stored procedures, etc, so I'm basically stuck with the db model as it is.
是的。一样!问题是我们的存储过程包含很多业务逻辑并且不是简单的 CRUD 过程,因此通过存储过程执行的各种更新来保持 ORM 更新一点也不容易——单一责任原则——不是一个好的打破!
My plan is to replace the old db access code with EF over time and get rid for the tight coupling
between UI layers and data layer.
也许您可以在不需要 ORM 的情况下解耦 - 如何在您的 UI 层前面放置一个服务/外观层来协调与底层域的所有交互并将其隐藏在 UI 中。
如果您的数据库是“王者”并且您的应用程序是高度数据驱动的,我认为您将始终在实现您提到的模式时打一场艰苦的战斗。
为这个项目拥抱 ado.net - 在你的下一个绿色领域项目中使用 EF4 和 DDD 模式 :)
关于c# - 用 Entity Framework 和 POCO 类替换遗留数据层的策略,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6068784/
这个问题在这里已经有了答案: 10年前关闭。 Possible Duplicates: What is a framework? What does it do? Why do we need a f
我在按照 http://msdn.microsoft.com/en-us/data/jj591621.aspx 处的 Microsoft Data Developer 过程启用代码优先迁移时遇到了一些
我正在从 迁移项目 Entity Framework 4.3 在 .net 4 上运行到 Entity Framework 5 在 .net 4.5 上运行。在不做任何更改的情况下,当我尝试运行该项目
我正在使用 Entity Framework 6 并使用 EntityFramework Extended 来执行一些批量更新和批量删除。批量更新和批量删除工作正常,但我还需要知道更新/删除的实体(即
我在实体上添加了一个列,然后从模型中生成数据库或构建解决方案,然后收到一条消息,提示我刚添加的新列未映射。该数据库以前是从模型创建的,没有错误。 当我右键单击Entity并选择Table Mappin
每次我尝试运行我的代码时都会崩溃,因为我尝试启动函数以调用 SDK 的任何部分。 我在构建过程中包含了 FoundationSDK: 并且我在头文件中包含了对 SDK 的引用: 但是每次我运行这个,我
我以前能够毫无问题地提交我的申请。我的工作流程中唯一改变的部分是使用 Sourcetree。在对以下框架进行更新后,我在提交到 iOS App Store 时收到此警告。我还收到一封电子邮件,其中包含
假设我为 Asp.NET Web 应用程序安装了 .NET Framework 2.0、3.0、3.5。 我意识到 Framework 3.0 和 3.5 只是 Framework 2 的扩展,不太清
是否有 SaveChanges 事件在保存更改后但在更新更改跟踪器之前触发? 我正在使用 EF 6。 我需要在某个实体的状态发生变化时执行任务。 我已经覆盖了 SaveChanges 来设置它。我可以
我正在使用一个现有的数据库,并且我已经将其中一个表映射为一个实体(因为我需要映射一个外键)。 因此,在初始化此数据库时,我希望 EF 忽略此实体,因为它已经存在。 我该怎么做? 最佳答案 您应该使用
我有 3 个表需要与 Entity Framework 进行映射,但我不确定解决此问题的正确方法。这是我的 3 个实体: public class User { [Key] public
我首先使用 VS 2010 和 Entity Framework 代码(版本 6)。我有两个实体,每个实体都在自己的上下文中,我想在它们之间创建一对多关系。 上下文 1 具有以下实体: public
我知道 EF 在 CodePlex 上是开源的,但我没有看到当前发布的 5.0 版本的分支。我在哪里可以得到这个源代码? 最佳答案 没有。他们只开源了 post 5 版本。第一次签到可能足够接近,但再
我们目前有一个数据库很大的系统,存储过程既用于CUD又用于查询。数据集用于从 SP 查询中检索结果。 现在我们正在研究使用 Entity Framework 针对同一个数据库开发另一个项目。在查询数据
我有一个每 10 秒运行一次的 Windows 服务......每次运行时,它都会获取一些测试数据,对其进行修改并使用 EntityFramework 将其保存到数据库中。但是,在每一秒运行时,当我尝
我对在我们的场景中仅将 Entity Framework 与存储过程一起使用的合理性有疑问。 我们计划拥有一个 N 层架构,包括 UI、BusinessLayer (BLL)、DataAccessLa
当我使用 Entity Framework 时,我想在上下文中查询出一条记录并将其添加到具有相同架构的另一个上下文中,在查询出记录后,我将其从上下文中分离出来,但是相关实体都没有了,是吗?有什么办法解
我正在使用 Entity Framework 5 构建 ASP.Net MVC4 Web 应用程序。我必须使用现有的 sql server 数据库,但也想使用 Code First,所以我遵循了本教程
在 Entity Framework 4.0 中使用 T4 模板创建 POCO 会丢失什么?为什么使用 Entity Framework 4.0 时的默认行为不创建 POCO? 最佳答案 你会失去很多
我在网上使用 Repository Pattern 和 EF 看了很多例子。但他们都没有真正谈到与相关实体的合作。 就像说用户可以有多个地址。 IUserRepository User CreateU
我是一名优秀的程序员,十分优秀!