2010-03-10 159 views
2

我有兩個表沒有任何級聯刪除。我想刪除所有子對象的父對象。我這樣做,這樣實體框架刪除子對象

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

回答

5

這足以設置

<OnDelete Action="Cascade" />
在模型的 CSDL part主關聯端。
在這種情況下,您的代碼將工作。

+3

還不夠完美。您需要1)加載所有相關實體或2)在DB中有一個級聯。 – 2010-03-18 13:40:26

1

我的情況稍有不同,它花了一段時間才弄清它,所以我認爲它值得記錄。我有兩個相關的表,報價和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()在中間 - 這往往只發生在這個系統的一個工作單元的末尾,所以我想要一些不依賴於此的東西。