【问题标题】:Deleting child objects with EF6使用 EF6 删除子对象
【发布时间】:2014-03-02 13:44:29
【问题描述】:

我是 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;
}

【问题讨论】:

    标签: c# asp.net-mvc entity-framework knockout.js entity-framework-6


    【解决方案1】:

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

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

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

    【讨论】:

    • 我已根据您的建议更改了代码,现在出现以下异常:无法更改关系,因为一个或多个外键属性不可为空。当对关系进行更改时,相关的外键属性将设置为空值。如果外键不支持空值,则必须定义新的关系,必须为外键属性分配另一个非空值,或者必须删除不相关的对象。
    • 必须添加 db.Entry(record).State = EntityState.Deleted;进入 foreach。
    • 如果您实际保存的是person 而不是model,则不必这样做。
    猜你喜欢
    • 2017-09-11
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2022-01-08
    • 1970-01-01
    • 2014-03-01
    • 1970-01-01
    • 2018-03-06
    相关资源
    最近更新 更多