TryUpdateModel / UpdateModel不起作用?

时间:2011-11-03 16:38:19

标签: asp.net-mvc-3 entity-framework updatemodel updateexception

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

这是我的代码:

    [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()。

有什么建议吗?

提前致谢!

干杯

1 个答案:

答案 0 :(得分:0)

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

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