繁体   English   中英

在MVC3的“编辑”操作中保存更改

[英]SaveChanges in Edit action of MVC3

我是MVC的新手,在保存操作的已编辑信息时遇到了麻烦。 每次尝试保存更改时,都会得到: 存储更新,插入或删除语句影响了意外的行数(0)。 自加载实体以来,实体可能已被修改或删除。 刷新ObjectStateManager条目。

这是我的代码:

    [Authorize]
    [HttpPost]
    public ActionResult Profile(designer thisDesigner)
    {
        if (ModelState.IsValid)
        {
            db.Entry(thisDesigner).State = System.Data.EntityState.Modified;

            try
            {
                db.SaveChanges();
            }
            catch (Exception)
            {
                return View(thisDesigner);
            }
        }

        return RedirectToAction("Profile");
    }

还尝试查询新对象,然后设置并保存新值,在这种情况下,不会出现异常,但不会保存数据。 这是代码:

    [Authorize]
    [HttpPost]
    public ActionResult Profile(designer thisDesigner)
    {
        designer updateDesigner = db.designers.Find(thisDesigner.designer_id);

        if (ModelState.IsValid && updateDesigner != null)
        {
            db.Entry(updateDesigner).OriginalValues.SetValues(thisDesigner);

            db.Entry(updateDesigner).State = System.Data.EntityState.Modified;

            try
            {
                db.SaveChanges();
            }
            catch (Exception)
            {
                return View(thisDesigner);
            }
        }

        return RedirectToAction("Profile");
    }

使它起作用:)只需将我的模型的所有属性添加到页面,就像这样:

@Html.HiddenFor(model => model.designer_id)
@Html.HiddenFor(model => model.designer_login_status)
@Html.HiddenFor(model => model.designer_register_date)
@Html.HiddenFor(model => model.designer_small_logo)
@Html.HiddenFor(model => model.designer_status)
@Html.HiddenFor(model => model.designer_vip_date)

并使用与第一个示例相同的代码:

[Authorize]
[HttpPost]
public ActionResult Profile(designer thisDesigner)
{
    if (ModelState.IsValid)
    {
        db.Entry(thisDesigner).State = System.Data.EntityState.Modified;

        try
        {
            db.SaveChanges();
        }
        catch (Exception)
        {
            return View(thisDesigner);
        }
    }

    return RedirectToAction("Profile");
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM