实体框架删除子对象

时间:2010-03-10 11:34:32

标签: asp.net entity-framework object

我有两个没有任何级联删除的表。我想删除所有子对象的父对象。我是这样做的

//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();

2 个答案:

答案 0 :(得分:5)

在模型的CSDL part中为主关联结束设置

<OnDelete Action="Cascade" />
就足够了。
在这种情况下,您的代码将起作用。

答案 1 :(得分:1)

我的情况略有不同,需要一段时间才能做到正确,所以我认为值得记录。我有两个相关的表,Quote和QuoteExtension:

  • 报价(父母,主键QuoteId)
  • QuoteExtension(报价,主键和外键QuoteId的计算字段)

我没有设置OnDelete动作来让它发挥作用 - 但是克雷格的评论(如果我可以投票那么多,我会!)让我发现了这个问题。当我没有加载QuoteExtension时,我试图删除Quote。因此,我找到了两种方法:

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()可能会有效 - 这往往只发生在这个系统的一个工作单元的末尾,所以我想要不依赖于此的东西。