Linq 无法删除尚未附加的实体的问题

文章标签: linq
2014-12-18 13:11:46     8 人阅读    

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(); 就可以了
 


原文地址:http://www.itmmd.com/201412/338.html
该文章由 萌萌的IT人 整理发布,转载须标明出处。

TextBox中, javascript (DatePicker)改变Text内容, 触发OnTextChanged事件失效的问题的处理方式   上一篇
下一篇  update语句更新多条记录, 标记下

精彩回复
发表评论
姓名:       

《程序员app》专门为程序员量身定做!