使用EF6删除子对象

时间:2014-02-05 21:28:56

标签: 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.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;
}

1 个答案:

答案 0 :(得分:0)

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

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

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