Linq删除个集合数据, 刚开始用的注释掉的那行, 会提示"无法删除尚未附加的实体"错误, 使用Attach方法依然不行. 想想以前用过DeleteAllOnSubmit没啥问题哈, 估计是_db对象的引用问题, 换了种写法就OK了.

 

                    //删掉所有工作组部门关联
                    //wgdrLst = WorkGroupDB.GetRelatedDepMappingInfo(gid).ToList();
                    wgdrLst = _db.t_WorkGroupDepartments_Rel.Where(gdr => gdr.WorkGroupID == gid).ToList();
                    if (wgdrLst != null && wgdrLst.Count() > 0)
                    {
                        _db.t_WorkGroupDepartments_Rel.DeleteAllOnSubmit(wgdrLst);
                        _db.SubmitChanges();
                    }

 

可能的原因是, 删除操作、更新操作, 依赖于_db对象的引用, WorkGroupDB调用另一个_db对象获取了数据, 而这个_db对象不是删除、更新操作使用的_db对象, 所以报错. 尝试吧方法名加个重载, 把_db当作参数传入, 注释掉的那行换成  wgdrLst = WorkGroupDB.GetRelatedDepMappingInfo(_db,gid).ToList(); 就可以了

 

 

相关文章:

  • 2021-10-28
  • 2021-06-09
  • 2022-12-23
  • 2021-06-29
  • 2021-12-27
  • 2021-12-13
  • 2022-01-30
  • 2022-02-23
猜你喜欢
  • 2022-12-23
  • 2021-05-25
  • 2022-12-23
  • 2022-12-23
  • 2022-01-08
  • 2021-07-30
  • 2021-06-30
相关资源
相似解决方案