我有以下代码来添加或更新Entity对象。根据我添加或更新对象的响应,通过主键查找对象。
添加记录是可行的,但在其更新过程中会给出这样的错误消息:“ ObjectStateManager中已存在具有相同键的对象。ObjectStateManager无法跟踪具有相同键的多个对象”
在我的MSSQL数据库中,我只有一条记录。
var v = db.Envelopes.Find(model.ReportDate, model.Service);
if (v == null)
{
db.Envelopes.Add(model);
db.SaveChanges();
ViewBag.status = "Record Add successfully";
ModelState.Clear();
}
else
{
db.Entry(model).State = EntityState.Modified;
db.SaveChanges();
}如何修复此错误消息?
发布于 2011-04-15 15:40:17
正如@anon所提到的,一旦使用相同的键加载了实体,就不能再附加model。更改必须应用于附着的实体。而不是这样:
db.Entry(model).State = EntityState.Modified;使用以下命令:
db.Entry(v).CurrentValues.SetValues(model);发布于 2011-04-16 04:54:35
如果之前的查询读取了要更新的实体,这就是您得到错误的原因,您可以将该查询更改为AsNoTracking。请参阅http://www.asp.net/entity-framework/tutorials/advanced-entity-framework-scenarios-for-an-mvc-web-application中的AsNoTracking示例
发布于 2011-04-15 12:23:05
我假设你是说你的错误发生在这里:
db.Entry(model).State = EntityState.Modified;一旦你执行Find(),你的信封就已经被你的上下文跟踪了。这意味着如果需要更改属性,只需在v上更改它,然后调用SaveChanges()。不要担心将状态设置为Modified。
https://stackoverflow.com/questions/5672255
复制相似问题