• EF 级联删除


    参考地址:

    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();
                }
    
  • 相关阅读:
    关于web测试收集
    Webdriver初探
    Java学习笔记 11/15:一个简单的JAVA例子
    持续集成环境搭建总结
    启动速度
    excel中用到的函数
    jmerter使用
    接口测试
    内存泄漏场景
    手机连接电脑那些事
  • 原文地址:https://www.cnblogs.com/Alex-Mercer/p/12297912.html
Copyright © 2020-2023  润新知