C# 使用EF6删除子对象

C# 使用EF6删除子对象,c#,asp.net-mvc,entity-framework,knockout.js,entity-framework-6,C#,Asp.net Mvc,Entity Framework,Knockout.js,Entity Framework 6,我是EF6的新手,这是我的一个附带项目,我正在努力了解如何删除/修改子行。我通常会用手摇这玩意儿,但我正在调查如何提高生产率 我有以下内容为我的淘汰模型提供JSON public JsonResult DetailsData(int? id) { var result = from p in db.People where p.Id == id select new { p.Id, p.Fir

我是EF6的新手,这是我的一个附带项目,我正在努力了解如何删除/修改子行。我通常会用手摇这玩意儿,但我正在调查如何提高生产率

我有以下内容为我的淘汰模型提供JSON

public JsonResult DetailsData(int? id)
{
    var result = from p in db.People
        where p.Id == id
        select new
        {
            p.Id,
            p.FirstName,
            p.SecondName,
            SicknessRecords = from s in p.SicknessRecords
                              select new
                              {
                                  s.Id,
                                  s.Description,
                                  s.Occurred,
                                  s.PersonId
                              }
        };

    return Json(result.First(), JsonRequestBehavior.AllowGet);
}
然后,在编辑后,下面的程序将接收它

[HttpPost]
public JsonResult DetailsData(Person model)
{
    if (ModelState.IsValid)
    {   //db.SaveChanges();
    }

    return null;
}
在浏览器中,我已经删除了两行,这将被正确地发送回服务器,但我不知道如何删除它们

更新:

[HttpPost]
public JsonResult DetailsData(Person model)
{
    if (ModelState.IsValid)
    {
        var item = (from p in db.People
            where p.Id == model.Id
            select p).First();

        var removedRecords = item.SicknessRecords.Except(model.SicknessRecords).ToList();
        foreach (var record in removedRecords)
        {
            item.SicknessRecords.Remove(record);
        }

        db.SaveChanges();
    }
    return null;
}

您已经知道发生了什么变化,这意味着您必须重新从数据库中选择原始人员。然后你可以做:

var removedRecords = person.SicknessRecords.Except(model.SicknessRecords);
for (var record in removedRecords)
{
    person.SicknessRecords.Remove(record);
}

您应该始终使用发布的数据修改原始记录,而不仅仅是直接保存发布的数据。

我已根据您的建议更改了代码,现在出现以下异常:无法更改关系,因为一个或多个外键属性不可为空。对关系进行更改时,相关外键属性设置为空值。如果外键不支持空值,则必须定义新关系,必须为外键属性分配另一个非空值,或者必须删除无关对象。必须添加db.Entry(record).State=EntityState.deleted;如果你真的保存了
person
而不是
model
,你就不应该这样做。