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,但它实际上是错误的并且不起作用.如果我尝试下载该源代码,设置我的环境,并在带有帖子的博客实体上进行保存,那些帖子就不会像人们想象的那样得到保存.
这有什么变通方法吗?
更新:这个答案是为 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计划添加通过属性配置此功能的支持时。