C# 保存MVC3编辑操作中的更改
我是MVC新手,在保存操作的编辑信息时遇到了麻烦。 每次尝试保存更改时,我都会得到: 存储更新、插入或删除语句影响了意外的行数(0)。自加载实体后,实体可能已被修改或删除。刷新ObjectStateManager条目。 这是我的密码:C# 保存MVC3编辑操作中的更改,c#,asp.net-mvc-3,entity-framework-4.1,C#,Asp.net Mvc 3,Entity Framework 4.1,我是MVC新手,在保存操作的编辑信息时遇到了麻烦。 每次尝试保存更改时,我都会得到: 存储更新、插入或删除语句影响了意外的行数(0)。自加载实体后,实体可能已被修改或删除。刷新ObjectStateManager条目。 这是我的密码: [Authorize] [HttpPost] public ActionResult Profile(designer thisDesigner) { if (ModelState.IsValid)
[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");
}