gpt4 book ai didi

c# - 将断开连接的实体附加到 Entity Framework

转载 作者:行者123 更新时间:2023-11-30 21:08:49 25 4
gpt4 key购买 nike

这已经困扰我一段时间了。我的问题如下。我有一个名为 xX 类型的实例。 X 是由 Entity Framework 生成的实体类。

在我的方法中,我从 Web 服务接收到 x,因此它没有附加到我的对象上下文,但我知道数据库中已经存在具有相同主键的元素,所以我想要更新它。我在方法中添加了以下主体,它运行良好:

objectContext.Xs.Attach(x);
objectContext.ObjectStateManager.ChangeObjectState(x, EntityState.Modified);
objectContext.SaveChanges();

到目前为止一切顺利。然而,我的 objectContext 不是通过这种方法创建的,突然这段代码停止工作并抛出一个 InvalidOperationException 并包含以下文本:

An object with the same key already exists in the ObjectStateManager. The ObjectStateManager cannot track multiple objects with the same key.

发生这种情况是因为在这段代码运行之前的某个时间,执行了以下代码:

objectContext.Xs.ToList();

这会从数据库中读取所有当前 X 对象,从而将它们添加到 ObjectStateManager。

然后我通过代码更改为:

objectContext.Xs.ApplyCurrentValues(x);
objectContext.SaveChanges();

这工作正常,但如果我再次删除 objectContext.Xs.ToList(); 行,我会得到另一个包含以下文本的 InvalidOperationException:

An object with a key that matches the key of the supplied object could not be found in the ObjectStateManager. Verify that the key values of the supplied object match the key values of the object to which changes must be applied.

所以现在我遇到了相反的问题。此方法不起作用,因为 ObjectStateManager 跟踪它。

此外,我还没有找到任何可靠的方法来确定我的 x 是否已经被跟踪,所以目前我添加了这样的代码:

try
{
objectContext.Xs.Attach(x);
objectContext.ObjectStateManager.ChangeObjectState(x, EntityState.Modified);
objectContext.SaveChanges();
}
catch(InvalidOperationException)
{
objectContext.Xs.ApplyCurrentValues(x);
}
objectContext.SaveChanges();

这意味着我正在使用异常处理作为正常的程序流(元素已经被 ObjectStateManager 跟踪几乎没有异常(exception)),而且我还有一个问题,我可能会捕获另一个不相关的 InvalidOperationException我应该用另一种方式处理。

所以我的问题是。有谁知道一个好的解决方案,或者至少有一个正确的方法来检查 x 是否被 ObjectStateManager 跟踪,这样我就可以根据它选择一种方法而不是 try/catch?

最佳答案

您需要检查是否已附加具有相同 EntityKey 的对象。尝试这样的事情:

string containerName = context.DefaultContainerName;
string setName = context.CreateObjectSet<X>().EntitySet.Name;
EntityKey key = new EntityKey(String.Format("{0}.{1}", containerName, setName),
"KeyProperty", x.KeyProperty);
if (context.ObjectStataManager.GetObjectStateEntry(key) != null)
{
// Apply current values
}
else
{
// Attach and set state
}

关于c# - 将断开连接的实体附加到 Entity Framework ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9411310/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com