首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ObjectStateManager中已存在具有相同键的对象。ObjectStateManager无法跟踪具有相同密钥的多个对象

ObjectStateManager中已存在具有相同键的对象。ObjectStateManager无法跟踪具有相同密钥的多个对象
EN

Stack Overflow用户
提问于 2011-04-15 12:02:50
回答 6查看 63.8K关注 0票数 52

我有以下代码来添加或更新Entity对象。根据我添加或更新对象的响应,通过主键查找对象。

添加记录是可行的,但在其更新过程中会给出这样的错误消息:“ ObjectStateManager中已存在具有相同键的对象。ObjectStateManager无法跟踪具有相同键的多个对象”

在我的MSSQL数据库中,我只有一条记录。

代码语言:javascript
复制
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();
}

如何修复此错误消息?

EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2011-04-15 15:40:17

正如@anon所提到的,一旦使用相同的键加载了实体,就不能再附加model。更改必须应用于附着的实体。而不是这样:

代码语言:javascript
复制
db.Entry(model).State = EntityState.Modified;

使用以下命令:

代码语言:javascript
复制
db.Entry(v).CurrentValues.SetValues(model);
票数 88
EN

Stack Overflow用户

发布于 2011-04-16 04:54:35

如果之前的查询读取了要更新的实体,这就是您得到错误的原因,您可以将该查询更改为AsNoTracking。请参阅http://www.asp.net/entity-framework/tutorials/advanced-entity-framework-scenarios-for-an-mvc-web-application中的AsNoTracking示例

票数 9
EN

Stack Overflow用户

发布于 2011-04-15 12:23:05

我假设你是说你的错误发生在这里:

代码语言:javascript
复制
db.Entry(model).State = EntityState.Modified;

一旦你执行Find(),你的信封就已经被你的上下文跟踪了。这意味着如果需要更改属性,只需在v上更改它,然后调用SaveChanges()。不要担心将状态设置为Modified。

票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5672255

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档