我有一个域模型架构,其中我的域/业务对象是基于问题域创建的,并且独立于物理数据模型或持久性结构的任何知识。到目前为止,我走上了正轨,因为这是完全可以接受的,而且通常情况下域模型和数据模型之间存在阻抗不匹配。DBA 创建了数据库来获取他们需要的数据,但它并没有封装应用程序的整个域模型或设计。
结果 - 我有自己的一组域模型对象。然而,所有需要持久化的字段确实存在于我的域模型中的某个或另一个位置,但不一定以我自动生成的 .edmx POCO 实体具有它们的形状存在。所以我有所有的数据,只是它的形状并不像创建自动生成的 POCO 实体的表那样完美。
我看过一些关于这个主题的帖子,比如将 POCO 实体转换为业务实体和Entity Framework 4 with Existing Domain Model,它们做出如下声明:
“在实体数据模型中创建与域类同名的实体。实体属性也应该与域类中的名称和类型相同”
什么!?没办法,为什么我必须将我的域模型重塑为完全按照数据库中的数据模型/表结构建模的 POCO?例如 - 在我有 5 个给定属性的情况下,2 个可能在“A”类中,3 个在“B”类中,而自动生成的 POCO 类在其自己的“A”类中具有全部 5 个。
这就是重点,我想要分离我的对象模型和数据模型,但仍然使用像 EF 5.0 这样的 ORM 在它们之间进行映射。我不想在数据模型中创建和塑造这样命名的类和属性。
现在我在 EF 5.0 中的 .edmx 正在为我生成 POCO 类,但我的问题是如何分解这些并将所有内容重新连接到包含所有这些数据但只是形状不同的域对象?
顺便说一句,使用 Code First 方法提出的任何解决方案都不是一个选项,因此请不要提供此选项。我需要一些使用 EF5 的指导或教程(最好)(如果可能,因为 EF4 示例总是从 ObjectContext 继承 POCO)并将我自己的业务对象连接到 .edmx。
感谢任何帮助或指导,谢谢!