【问题标题】:EF One child for multiply parrentsIF 多个父母一个孩子
【发布时间】:2016-05-19 11:15:23
【问题描述】:

我有这样的 EF6 Code First 模型设计。从Another 类知道谁是家长(ParentAParentB)的最佳方法是什么。谢谢!

public class Child
{
    public int Id { get; set; }
    public List<Another> AnotherList { get; set; }
}

public class Another
{
    public int Id { get; set; }
    public int ChildId { get; set; }
    public Child Child { get; set; }
    public string AnotherName { get; set; }
}

public class ParentA
{
    public int Id { get; set; }
    public int ChildId { get; set; }
    public Child Child { get; set; }
}

public class ParentB
{
    public int Id { get; set; }
    public int ChildId { get; set; }
    public Child Child { get; set; }
}

public class Context : DbContext
{
    public DbSet<ParentA> ParentA { get; set; }
    public DbSet<ParentB> ParentB { get; set; }
    public DbSet<Child> Child { get; set; }
    public DbSet<Another> Another { get; set; }
}

【问题讨论】:

  • Child 需要一个 ParentA 和一个 ParentB 属性,将其变成两个 1:1 关联。 I 另一种方法称为多态关联,但如果不是绝对必要,我不会这样做。

标签: c# .net entity-framework entity-framework-6 relationship


【解决方案1】:

在上述设置中,EF 将在父子节点之间建立一对多的关系。但是,如果 ParentA 和 ParentB 可以引用同一个孩子,您可能希望将其配置为多对多。您可以在 EF 文档中找到如何操作:http://www.entityframeworktutorial.net/code-first/configure-many-to-many-relationship-in-code-first.aspx

关于如何找出谁引用了孩子的问题,您可以制定一个简单的查询,例如:

context.ParentAs.Where(p => p.ChildId == id).Any()

这将告诉您是否存在引用您孩子的 ParentA。

如果你想让它更优雅,你可以把两个父母联系起来:

class Parent{ /* ... */ }
class ParentA : Parent{ /* ... */ }
class ParentB : Parent { /* ... */ }

然后从 Child 引用 Parent,而不是反过来:

class Child
{
    public Parent Parent{ get; set; }
    // ...
}

【讨论】:

  • 感谢您的回复,罗兰。问题是 ParentA 和 ParentB 已经从其他类继承,例如 ParentA: Class1, ParentB: Class2。
  • 好的。然后你仍然可以使用子查询,但是在你的域模型中很难有对应的属性......
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2023-03-18
  • 1970-01-01
  • 2018-01-15
相关资源
最近更新 更多