首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >通过EF将新数据提交到数据库,附加/添加时出现错误

通过EF将新数据提交到数据库,附加/添加时出现错误
EN

Stack Overflow用户
提问于 2009-09-04 15:49:25
回答 2查看 261关注 0票数 0

所以我开始在我的网站(C#)上使用EF,但我遇到了一点小麻烦。用户可以创建或修改数据,他们将使用选择屏幕执行此操作(第1页)。如果用户选择创建新数据,我将执行以下代码:

代码语言:javascript
复制
Program newProg = new Program();
using (DatabaseEntities context = new DatabaseEntities())
{
Guid id = new Guid(list.SelectedValue);
var itemString = from item in context.Set where item.Id == id select item;
Item selectedItem = itemString.ToList()[0];
newProg.Items.Add(selectedItem);
context.AddToProgramSet(newProg);
context.Detach(newProg);
}

这相当于创建了一个新的“Program”实例,它将沿着每个用户控件传递,直到用户准备提交到数据库为止。此时将执行以下代码:

代码语言:javascript
复制
   using (DatabaseEntities context = new DatabaseEntities())
   {
        context.AddToProgramSet(this.SummaryControl.SelectedProgram);
        context.SaveChanges();
   }

不幸的是,当我到达那里时,我收到了以下消息:

无法将该对象添加到ObjectStateManager,因为它已具有EntityKey。使用ObjectContext.Attach附加具有现有关键点的对象。

在这一行中:

代码语言:javascript
复制
context.AddToProgramSet(this.SummaryControl.SelectedProgram);

另外,当我在上一行之前添加以下行时:

代码语言:javascript
复制
context.Attach(this.SummaryControl.SelectedProgram);

我得到了这个错误:

不能将具有空EntityKey值的对象附加到对象上下文。

任何帮助都将不胜感激。谢谢。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2009-09-04 17:28:29

此错误的根本原因是您试图将一个实体添加为已经设置了其主键的新实体。

在什么时候将实体添加到SummaryControl?您的第一个代码片段展示了如何添加实体:

代码语言:javascript
复制
...
newProg.Items.Add(selectedItem);
context.AddToProgramSet(newProg);
context.Detach(newProg);
...

然后,您似乎再次添加了它:

代码语言:javascript
复制
using (DatabaseEntities context = new DatabaseEntities())
   {
        context.AddToProgramSet(this.SummaryControl.SelectedProgram);
        context.SaveChanges();
   }

如果newProgthis.SummaryControl.SelectedProgram是同一实体,则您已尝试将其添加两次。从第一个代码段中删除context.AddToProgramSet(newProg);,在实体上工作,然后将其添加到ProgramSet。

票数 1
EN

Stack Overflow用户

发布于 2009-09-08 18:16:39

Dave是对的,根本原因是实体已经有了主键。

您的代码中没有显示的一件事是:

代码语言:javascript
复制
Program newProg = new Program();

变成:

代码语言:javascript
复制
this.SummaryControl.SelectedProgram

修复它的一种方法是在开始向其中添加项之前将newProg保存到数据库中。

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

https://stackoverflow.com/questions/1380064

复制
相关文章

相似问题

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