【问题标题】:How do I build this EF relationship?如何建立这种 EF 关系?
【发布时间】:2014-08-13 12:28:51
【问题描述】:

我可以在数据库中执行此操作,但我想先了解如何执行此代码。

我有这门课:

public class Component
{
    public Guid ID { get; set; }
    public Guid Name { get; set; }

    public virtual Component Master { get; set; }
    public virtual ICollection<Component> Components { get; set; }
}

一个组件可以有很多子组件。 一个组件也可以是许多其他组件中的子组件。

我想创建一个将组件的 ID 关联在一起的表。最好的表达方式是什么?

【问题讨论】:

  • 创建将 id 关联在一起的表是什么意思?为什么不使用带有 FK 的表作为父组件?
  • 这行不通,因为一个组件可以有多个父级(主)。我的意思是一个交叉引用表,例如 Dismissle 的答案。
  • 那么,也许您需要大师收藏?否则你想选哪一个做master?
  • 是的,当我加载子组件时,我只想要一个主控,但现在我知道我需要做什么才能让 EF 理解我想要的数据结构。 Dismissle 的回答很到位。

标签: c# entity-framework asp.net-mvc-4 ef-code-first


【解决方案1】:

当你有一个像这样的自引用实体只能有一个父级时:

public class Component
{
    public Guid ID { get; set; }
    public Guid Name { get; set; }

    public virtual Component Master { get; set; }
    public virtual ICollection<Component> Components { get; set; }

    // reference to the parent guid (if any)
    public Guid? MasterID { get; set; }
}

要配置实体关系,请在 OnModelCreating 中执行此操作:

protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
    modelBuilder.Entity<Component>()
        .HasMany(c => c.Components)
        .WithOptional(c => c.Master)
        .HasForeignKey(fk => fk.MasterID);
}

另一种选择是设置一个外部参照/连接表,而不是将其作为组件表上的一列,但在这种情况下,您拥有多对多关系,因此您拥有一个集合而不是单个组件主控组件作为 Master。您可以使用唯一键将其强制为单亲,但您仍然必须从 EF 的角度将其建模为集合。

以下是使用外部参照表的示例:

public class Component
{
    public Guid ID { get; set; }
    public Guid Name { get; set; }

    public virtual ICollection<Component> Masters { get; set; }
    public virtual ICollection<Component> Components { get; set; }       
}

protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
    modelBuilder.Entity<Component>()
        .HasMany(c => c.Components)
        .WithMany(c => c.Masters)
        .Map(xref => xref.MapLeftKey("ParentID").MapRightKey("ChildID").ToTable("ComponentXref"));
}

【讨论】:

  • 这会创建我希望在数据库中看到的内容,但没有任何保存?只有 ID 从 UI 传回,我正在创建一个新组件,设置其 ID,将父组件添加到 Masters 并将子组件添加到 masters Child 集合。数据库中没有出现任何内容 - 是否缺少某些内容?
  • @Cari 我必须查看您的代码才能理解您的意思。
  • 没关系,我假设当我需要编写更多代码时事情会神奇地发生。
猜你喜欢
  • 1970-01-01
  • 2020-06-28
  • 1970-01-01
  • 2021-04-19
  • 2015-01-14
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多