EF 7 beta 6:EF 7中具有一对多关系的实体

Lut*_*ndo 8 c# entity-framework entity-framework-core

我有一个非常简单的模型:

class Bag
{
    public int Id { get; set; }
    public ICollection<RandomThing> RandomThings { get; set; }
}

class RandomThing
{
    public int Id { get; set; }
    public String Description{ get; set; }
}
Run Code Online (Sandbox Code Playgroud)

我的上下文OnModelCreating(在EF 6中)是这样的:

protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
    base.OnModelCreating(modelBuilder);

    modelBuilder.Entity<Bag>()
        .ToTable("Bag")
        .HasMany(x => x.RandomThings).WithRequired(x => x.Bag).WillCascadeOnDelete();

    modelBuilder.Entity<RandomThing>().ToTable("RandomThing");
}
Run Code Online (Sandbox Code Playgroud)

据我所知,没有相同的方法可以做到这一点.我知道不支持级联删除.但是,我想知道,在我的代码示例中定义的一对多关系建模的最佳方法是什么?似乎所有这些东西已经消失(或者尚未实施).

我已经看到了一个与我想要的完全一样的例子(这里)DbContext,但它实际上是错误的并且不起作用.如果我尝试下载该源代码,设置我的环境,并在带有帖子的博客实体上进行保存,那些帖子就不会像人们想象的那样得到保存.

这有什么变通方法吗?

nat*_*ter 3

更新:这个答案是为 EF7 beta7 编写的。API 自此发生了变化。有关使用 EF Core 的最新信息,请参阅http://docs.efproject.net/en/latest/modeling/relationships.html 。

原答案

在 EF 7 中,您可以在 OnModelCreating 方法中配置一对多关系。为此,请向 RandomThing 添加一个属性来表示外键,以及对父类型的 CLR 引用。

class Bag
{
    public int Id { get; set; }
    public ICollection<RandomThing> RandomThings { get; set; }
}

class RandomThing
{
    public int Id { get; set; }
    public String Description{ get; set; }

    public Bag Bag { get; set; }
    public int BagId { get; set; }
}
Run Code Online (Sandbox Code Playgroud)

在您的上下文中,使用以下设置配置关系:

protected override void OnModelCreating(ModelBuilder modelBuilder)
{  
    modelBuilder.Entity<RandomThing>()
        .Reference(e => e.Bag)
        .InverseCollection(p => p.RandomThings)
        .ForeignKey(e => e.BagId);
}
Run Code Online (Sandbox Code Playgroud)

旁注:当 EF 7计划添加通过属性配置此功能的支持时。