实体框架:删除子实体

时间:2016-09-01 15:30:22

标签: c# entity-framework linq

我正在尝试从新闻中删除类别对象,但它不起作用

我的代码如下所示:

var OriginalCategoriesIds = db.News.Where(w => w.NewsId == 1)
                                   .SelectMany(v => v.Categories)
                                   .ToList();
News NewsToUpdate = new News() { NewsId = 1 };
db.News.Attach(NewsToUpdate);

foreach (var category in OriginalCategoriesIds)
{
    if (!model.SelectedCategoriesIds.Contains(category.CategoryId))
    {
        NewsToUpdate.Categories.Remove(category);
    }
}

db.SaveChanges();

2 个答案:

答案 0 :(得分:1)

以下是您的问题:

var OriginalCategoriesIds = db.News.Where(w => w.NewsId == 1).SelectMany(v => v.Categories).ToList();
                            News NewsToUpdate = new News() { NewsId = 1 };
                            db.News.Attach(NewsToUpdate);

                            foreach (var category in OriginalCategoriesIds)
                            {
                                if (!model.SelectedCategoriesIds.Contains(category.CategoryId))
                                {
                                    db.News.Categories.Remove(category);// <---change like this
                                }

                            }

                            db.SaveChanges();

答案 1 :(得分:0)

EF应足够聪明,可以查看更新的实体,并根据存在的实体了解要删除的实体。而不是检查哪些不再属于,检查哪些做。理论上它应该正确同步。此外,您很可能还想检查哪些是不存在的。不要从新闻中加载现有的类别ID,只需加载现在附加的所有ID,然后将它们全部添加。

   News NewsToUpdate = new News() { NewsId = 1 };
   var updatedCategoryIds = model.SelectedCategoriesIds;
   NewsToUpdate.Categories.AddRange(db.Categories.Where(c => updatedCategoryIds.Contains(c.CategoryId));
   db.News.Attach(NewsToUpdate);
   db.SaveChanges();
相关问题