我有一个非常简单的模型:
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; }
}
我的上下文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");
}
据我所知,没有相同的方法可以做到这一点。我知道cascade deletes are not supported。但是,我想知道,在我的代码示例中定义的一对多关系建模的最佳方法是什么?似乎所有这些东西已经消失(或者尚未实施)。
我看到DbContext
的一个例子(here)与我想要的完全一样,但它实际上是错误的并且不起作用。如果我尝试下载该源代码,设置我的环境,并在带有帖子的博客实体上进行保存,那些帖子就不会像人们想象的那样得到保存。
这有什么变通方法吗?
答案 0 :(得分:3)
更新:这个答案是针对EF7 beta7编写的。 API已经改变了。有关使用EF Core的最新信息,请参阅http://docs.efproject.net/en/latest/modeling/relationships.html。
原始答案
在EF 7中,您可以在OnModelCreating方法中配置一对多关系。为此,请将属性添加到RandomThing以表示forign键,以及对父类型的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; }
}
在您的上下文中,使用以下设置配置关系:
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<RandomThing>()
.Reference(e => e.Bag)
.InverseCollection(p => p.RandomThings)
.ForeignKey(e => e.BagId);
}
旁注:当EF 7 plans to add support用于通过属性进行配置时。
答案 1 :(得分:0)
虽然我根本没有使用EF7,但在EF6中,我会让你的模型看起来像这样:
class Bag
{
public int Id { get; set; }
public virtual ICollection<RandomThing> RandomThings { get; set; }
}
class RandomThing
{
public int Id { get; set; }
public String Description{ get; set; }
public int BagId {get; set;}
[ForeignKey("BagId")]
Public Bag Bag {get; set;}
}
这种关系通过数据注释得到处理,并且您不需要model builder
来执行此特定任务