Entity Framework удалить дочерний объект - PullRequest
2 голосов
/ 10 марта 2010

У меня есть две таблицы без каскадного удаления. Я хочу удалить родительский объект со всеми дочерними объектами. Я делаю это так

//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 ]

5 голосов
/ 10 марта 2010

Достаточно установить

<OnDelete Action="Cascade" />
для конца основного соединения в CSDL-детали модели.
В этом случае ваш код будет работать.
1 голос
/ 06 августа 2012

Моя ситуация была немного другой, и потребовалось некоторое время, чтобы понять это правильно, поэтому я подумал, что это стоит документировать. У меня есть две связанные таблицы, Quote и QuoteExtension:

  • Цитата (родительский, первичный ключ QuoteId)
  • QuoteExtension (Вычисляемые поля для Quote, первичного и внешнего ключа 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 () посередине - это обычно происходит только в конце единицы работы в этой системе, поэтому я хотел то, что не полагалось на это.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...