1

我正在尝试更新数据库中存在的多个对象并保存新对象,但它不起作用?

这是我的代码:

    [HttpPost]
    public ActionResult Edit(MasterModel Model)
    {
        DBEntities db = new DBEntities();
        var reloadView = true;
        for(int i = 0 ;i< Model.Emails.Count(); i++)
        {
            if(Model.Emails[i].ID > 0 )
            {
                var id = Model.Emails[i].ID;
                var email = db.EMAIL.Single(e=> e.ID == id);
                if(TryValidateModel(Model.Emails[i], "Emails[" +i.ToString() + "]"))
                {
                    TryUpdateModel(email, "Emails[" + i.ToString() + "]");
                    reloadView = false;
                }
                else
                {
                    reloadView = true;
                }

            }
            else
            {
                if(TryValidateModel(Model.Emails[i], "Emails[" + i.ToString() + "]"))
                {
                    db.AddToEMAIL(Model.Emails[i]);
                    reloadView = false;
                }
                else
                {
                    reloadView = true;
                }
            }
        }

        if(reloadView)
        {
            return View(Model);
        }
        else
        {
            db.SaveChanges();
            return RedirectToAction("Index");
        }
    }

如果在 TryUpdateModel 之后我执行 db.SaveChanges(); 我得到一个具有引用完整性的 System.Data.UpdateException

如果我让我的代码像示例中一样,它就不会更新!:S

哦,是的,我也尝试过 UpdateModel() 。

有什么建议么?

提前致谢!

干杯

4

1 回答 1

0

更新对象的通常工作流程是:

1)加载旧对象(使用 id) 2)更改属性 3)SaveChanges

于 2011-11-03T16:57:37.040 回答