如何在entityframework中配置一对多关系以及继承

时间:2015-06-09 10:32:06

标签: c# entity-framework ef-code-first

我正在研究实体框架代码的第一个模式。我有一个场景,我有以下实体,

public class Toy
{
public int ID {get; set;}
public string Name {get; set;}
}

对于上述实体,所有模型构建配置都已完成,并且表创建正常。

我们有另一个实体,

public class Kid
{
public string Name {get; set;}
}

对于这个实体,所有模型构建配置都已完成,并且数据库中的表格很好。

现在我需要保持/配置,孩子和玩具之间的一个很多关系,即一个孩子可以有多个玩具

所以我创建了一个将继承Kid类的自定义类

public class KidToy : Kid
{
public virtual List<Toy> Toys{get; set;}
}
  

注意:我无法直接在Kid类中添加List Toys属性,我是   得到循环引用错误。

builder.Entity<Kid>().Map<KidToy>(m => {

            });

            builder.Entity<KidToy>().HasMany(b => b.Toys).WithMany().Map(b =>
            {
                b.MapLeftKey(KidId");
                b.MapRightKey("ToyId");
                b.ToTable("kidToyMap");
            });

我不需要为自定义模型类(KidToy)创建表,我需要配置一对多的关系。你能指导我吗?

1 个答案:

答案 0 :(得分:0)

使用它:

public class Toy
{
    public int ID { get; set; }
    public string Name { get; set; }

    public int KidID { get; set; }

    [ForeignKey("KidID")]
    [InverseProperty("Toys")]
    public virtual Kid Kid { get; set; }
}

public class Kid
{
    public string Name { get; set; }

    [InverseProperty("Kid")]
    public virtual ICollection<Toy> Toys { get; set; }
}