参考地址:
EF配置级联删除代码如下
modelBuilder.Entity<Doc>().HasMany(a => a.Lines).WithRequired(a => a.Doc).HasForeignKey(a => a.DocNo); //单头
modelBuilder.Entity<Line>().HasRequired(a => a.Doc).WithMany().HasForeignKey(a => a.DocNo).WillCascadeOnDelete(true); //表体
有的小伙伴实验发现,明明我配置好了,为什么删除的时候没有把级联的一起删除呢。
- 一对多场景,在子对象映射中开启级联删除情况下,删除父对象将自动删除其下所有子对象,需要注意一些事项:
- √ 需要保证DbContext中已经加载了该父对象的所有子对象。
- X 如果DbContext内未加载子对象将不级联删除子对象,
- X 如DbContext只加载部分子对象也只级联删除这些子对象。
- 因此在查询父对象只应该使用Include("子对象属性名")查询(请看示例代码3)或者在DbContext另外把其下所有子对象查询出来(请看示例代码4),再进行对父对象的删除方可级联删除子对象。
- 但注意以上所述情况只适用于关联子项比较少的情况,数据量少的演示测试Demo可以,工作中应该杜绝该类解决方案的出现。
也就是说要用Include加载 出级联对象。这是参考地址中的治标方法,治本方法暂时看不懂
using (var db = new Data())
{
var temp = db.Doc.Include("Lines").FirstOrDefault(a => a.DocNo.Equals(DocNo));
db.Doc.Remove(temp);
db.SaveChanges();
}