9

我试图了解 EF4 中的继承映射。

我的数据库有两个具有以下结构的表:

人员类别表:

  • CategoryID (int) (身份) (PK)
  • 类别类型 (nvarchar(50))

人表

  • PersonID (int) (身份) (PK)
  • CategoryID(来自 PersonCategory 表的 FK)
  • 名称 (nvarchar(50))
  • 说明 (nvarchar(max))

PersonCategory 表有四个条目,每个条目代表一个类别 - Student、CourseInstructor、Staff 和 A​​dvisor。

通过在线阅读文章,我认为Table Per Hierarchy将是适合这种情况的模型。所以在 EF4 中,我创建了四个实体(Student、CourseInstructor、Staff 和 A​​dvisor),每个实体都继承自 Person 表。然后,我将它们中的每一个映射到 Person 表,并为每个表添加一个条件(例如,对于 Student 实体,CategoryID = 1,对于 Staff 实体,CategoryID = 2)以区别于其他实体。我还从 Person 表中删除了 CategoryID 属性并将其设为抽象类。但是我收到以下错误,因为我从 Person 表中删除了 CategoryId 属性。

错误 3015:从第 101、108、114、120、126、133 行开始映射片段时出现问题:从表 Person (CategoryID) 到表 PersonCategory (CategoryID) 的外键约束“FK_Person_PersonCategory”::映射不足:必须映射外键到一些在概念方面参与外键关联的 AssociationSet 或 EntitySets。

Table Per Hierarchy 是否适合这种情况?如果不是,那么我应该如何在 EF4 中处理这种情况?

4

3 回答 3

5

在关联中使用鉴别器列是有问题的。看:-

http://social.msdn.microsoft.com/Forums/en/adodotnetentityframework/thread/24380ee6-4753-46a2-a3ed-b1cb2e2d161c

“关键是作为鉴别器的列不能映射到关联,除非它参与非空条件。”

于 2010-11-10T18:56:11.817 回答
0

我认为您真正想要的是每种类型的表 http://www.robbagby.com/entity-framework/entity-framework-modeling-table-per-type-in​​heritance /

于 2010-11-17T02:51:17.163 回答
0

对于 Table-per-Hierarchy,单个表包含所有类型的所有列。你有两张桌子,所以我立即怀疑。

如果选择每个类型的表,那么它也不正确。您只能有两种类型,基本类型和派生类型,而 PersonCategory 表为派生类型的属性值提供数据。但是,这需要将 PersonID 作为外键,而它没有。

就个人而言,我认为您不必要地将实体分成不同的类型。您可以将两个表中的所有列映射到一个实体,或者如果可能,更改数据库架构以更好地满足您的需求。

我建议使用空的测试数据库并进行 TPT 和 TPH 模型优先设计,并查看 EF 为您所需的设置构建的架构。

卢克

于 2012-07-03T14:18:54.297 回答