不错呦!smile@林凯西,确保“准备文件”中的几个文件都有安装,S...您好,看了您这篇帖子觉得很有帮助。但是有个问题想请...我的修改过了怎么还被恶意注册呢 @jjjjiiii 用PJ快9年了,主要是A...PJ3啊,貌似很少有人用PJ了,现在不是WP就是z...@332347365,我当时接入时错误码没有-10...楼主,ChkValue值应为-103是什么意思呢?...大哥 你最近能看到我发的信息,请跟我联系,我有个制...
ASP.NET MVC3更新出错:ObjectStateManager中已存在具有同一键的对象
编辑:dnawo 日期:2013-05-08
复制内容到剪贴板 程序代码
[HttpPost]
public ActionResult Edit(Person person)
{
if (ModelState.IsValid)
{
Person oldperson = db.People.Where(p => p.Id == person.Id).FirstOrDefault();
//TODO
db.Entry(person).State = EntityState.Modified;
db.SaveChanges();
return RedirectToAction("Index");
}
return View(person);
}
public ActionResult Edit(Person person)
{
if (ModelState.IsValid)
{
Person oldperson = db.People.Where(p => p.Id == person.Id).FirstOrDefault();
//TODO
db.Entry(person).State = EntityState.Modified;
db.SaveChanges();
return RedirectToAction("Index");
}
return View(person);
}
上边代码试图在更新person到数据库前取出旧数据(oldperson)进行文件删除等操作,结果页面报错:
引用内容
ObjectStateManager 中已存在具有同一键的对象。ObjectStateManager 无法跟踪具有相同键的多个对象。
若是不取旧数据,该段代码执行可以正常执行,经过一番测试,猜测原因是读取旧数据时,对象会被添加到db中,当执行"db.Entry(person)"时,试图把person也添加到db中,但person和先前添加对象的键值是一样的,因而报错,这也解释了为什么不取旧数据不出错。
下边提供三种解决方法:
复制内容到剪贴板 程序代码
Person oldperson = db.People.Where(p => p.Id == person.Id).FirstOrDefault();
//TODO
oldperson.PicUrl = person.PicUrl;
db.SaveChanges();
//TODO
oldperson.PicUrl = person.PicUrl;
db.SaveChanges();
复制内容到剪贴板 程序代码
Person oldperson = db.People.AsNoTracking().Where(p => p.Id == person.Id).FirstOrDefault();
//TODO
db.Entry(person).State = EntityState.Modified;
db.SaveChanges();
//TODO
db.Entry(person).State = EntityState.Modified;
db.SaveChanges();
复制内容到剪贴板 程序代码
Person oldperson = db.People.Where(p => p.Id == person.Id).FirstOrDefault();
//TODO
db.Entry(oldperson).CurrentValues.SetValues(person);
db.SaveChanges();
//TODO
db.Entry(oldperson).CurrentValues.SetValues(person);
db.SaveChanges();
参考资料
[1].An object with the same key already exists in the ObjectStateManager. The ObjectStateManager cannot track multiple objects with the same key
评论: 0 | 引用: 0 | 查看次数: 10519
发表评论
请登录后再发表评论!