实体框架删除子对象
问题描述:
我有两个表没有任何级联删除。我想删除所有子对象的父对象。我这样做,这样实体框架删除子对象
//get parent object
return _dataContext.Menu.Include("ChildMenu").Include("ParentMenu").Include("Pictures").FirstOrDefault(m => m.MenuId == id);
//then i loop all child objects
var picList = (List<Picture>)menu.Pictures.ToList();
for (int i = 0; i < picList.Count; i++)
{
if (File.Exists(HttpContext.Current.Server.MapPath(picList[i].ImgPath)))
{
File.Delete(HttpContext.Current.Server.MapPath(picList[i].ImgPath));
}
if (File.Exists(HttpContext.Current.Server.MapPath(picList[i].ThumbPath)))
{
File.Delete(HttpContext.Current.Server.MapPath(picList[i].ThumbPath));
}
//**what must i do here?**
//menu.Pictures.Remove(picList[i]);
// DataManager dm = new DataManager();
// dm.Picture.Delete(picList[i].Id);
//menu.Pictures.de
//_dataContext.SaveChanges();
//picList[i] = null;
}
//delete parent object
_dataContext.DeleteObject(_dataContext.Menu.Include("ChildMenu").Include("ParentMenu")
.Include("Pictures").FirstOrDefault(m => m.MenuId == id););
_dataContext.SaveChanges();
答
我的情况稍有不同,它花了一段时间才弄清它,所以我认为它值得记录。我有两个相关的表,报价和QuoteExtension:
- 报价(父,主键QuoteId)
- QuoteExtension(报价,小学及外键QuoteId计算字段)
我没有必须设置OnDelete动作才能使其工作 - 但克雷格的评论(如果我可以把它投得更多,我会!)让我发现了这个问题。当QuoteExtension未加载时,我试图删除报价。因此,我发现了两种方式工作:
var quote = ent.Quote.Include("QuoteExtension").First(q => q.QuoteId == 2311);
ent.DeleteObject(quote);
ent.SaveChanges();
或者:
var quote = ent.Quote.First(q => q.QuoteId == 2311);
if (quote.QuoteExtension != null)
ent.Refresh(RefreshMode.ClientWins, quote.QuoteExtension);
ent.DeleteObject(quote);
ent.SaveChanges();
有趣的是试图删除QuoteExtension手动没有工作(虽然它可能如果我包括ent.SaveChanges()在中间 - 这往往只发生在这个系统的一个工作单元的末尾,所以我想要一些不依赖于此的东西。
还不够完美。您需要1)加载所有相关实体或2)在DB中有一个级联。 – 2010-03-18 13:40:26