如何使用Entity Framework Code First和DDD创建数据库?

Jür*_*yer 5 domain-driven-design entity-framework ef-code-first

要使用实体框架实现域驱动设计,我使用Julie Lerman在TechEd North America 2013上提出的方法(http://channel9.msdn.com/Events/TechEd/NorthAmerica/2013/DEV-B336#fbid=4tnuPF6L-Jc).此方法使用EF实体类作为域类.对于不同的有界上下文,域实体类具有不同的属性,甚至可以有不同的名称,尽管它们将数据存储在同一个表中.示例是"客户服务"有界上下文中的客户,实际上是"客户",但在"发货"有界上下文中,他是仅具有客户属性子集的"收件人".对于每个有界上下文,存在不同的EF上下文,其仅包括有界上下文所需的实体的DbSet.通过重写OnModelCreating,我们甚至可以排除与有界上下文无关的引用实体.使用POCO可以很容易地实现这一部分.

问题是使用Code First时的数据库创建.如果我们让Code First为每个不同的EF上下文创建数据库,我们最终会得到几个数据库.如果我们在EF上下文的构造函数中定义数据库名称,则使用第一个使用的EF上下文创建数据库,并在使用第二个EF上下文时丢失InvalidOperationException(说模型已更改)(缺少实体,缺少属性等).如果使用的EF上下文在使用之前使用其他EF上下文的实体/成员,我们可能会使用迁移来更新数据库.但是,这肯定会与正常使用迁移相混淆,并且无法正常运行.作为临时解决方案,我仅使用单独的EF上下文来创建数据库.这意味着我必须再次为此目的实现所有EF实体.

我相信还有其他解决方案.所以,请(朱莉)告诉我们如何.

Dra*_*uka 2

从本质上讲,我相信您必须拥有一个定义了所有“表”并驱动迁移的主上下文。该上下文用于创建数据库。

所有后续的“有界”上下文都将在其构造函数中包含 Database.SetInitializer(null),以防止它们篡改数据库架构。

此外,您的主上下文和“有界”上下文都应该继承自具有连接字符串和此类集的抽象上下文基类。

当您的应用程序启动时,您可以简单地尝试实例化您的主上下文并确保它已迁移到最新版本。但在稍后的实际应用程序中,您仅使用仅实现主上下文的子集的“有界”上下文。

我意识到你已经部分或全部做了其中的一些事情,但我认为这就是要走的路。