【问题标题】:Should I use Table-per-hierarchy?我应该使用每个层次结构的表吗?
【发布时间】:2012-07-27 22:15:27
【问题描述】:

已更新,底部有图片

我有三个实体 - 公司、项目、员工。

公司有一名或多名公司经理。 项目只有一个 ProjectManager。 Employee 只有一个 EmployeeManager

我想创建一个数据库设计,然后为此创建 EF Code First 模型。

我应该创建单独的表来存储 CompanyManagers、ProjectManagers 和 EmployeeManagers

或者

我应该创建一个存储各种经理的表吗?这样的表可能如下所示: 经理ID

EntityType(公司、项目、员工)

EntityID(CompanyID、ProjectID、EmployeeID)

更新 这是目前的设计:

【问题讨论】:

  • 使用哪种策略取决于您提供的详细信息的更多因素,a.o.所有类型共有的字段数。从here 开始,一系列有助于您做出此决定的优秀帖子。

标签: entity-framework database-design


【解决方案1】:

我们不知道 - 这取决于您的应用程序要求。无论如何,即使使用 TPH,您仍然会有单独的 CompanyIDProjectIDEmployeeID 列,因为映射到派生类型的特定属性的列不能被重用,并且您不能在列上建立条件关系。

【讨论】:

  • 我可以使用 EntityType 或 EntityType 和 EntityID 的组合作为此表和实体的鉴别器列。我不会将该表与任何其他表映射。该表将仅用于存储各种管理器。如果不建议这样做,请您提供其他建议。到目前为止,我已经用设计图更新了这个问题。我现在需要存储各种管理器。感谢您在这方面的时间。
猜你喜欢
  • 1970-01-01
  • 2018-07-04
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多