我正在尝试从新闻中删除类别对象,但它不起作用
我的代码如下所示:
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();
答案 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();