gpt4 book ai didi

.net - 在数据库中删除行后更新 DbSet.Local

转载 作者:行者123 更新时间:2023-12-04 02:42:16 25 4
gpt4 key购买 nike

我有一个与 DbContext 关联的 DbSet(使用 Entity Framework 4.3)。DbSet 最初加载了给定表 X 的所有实体问题是在删除该表的一行或几行(由另一个应用程序中的另一个 DbContext 完成删除)后,我无法重新加载 DbSet 以获取表 X 的最新列表。

这是我用来重新加载表中所有实体的行:

 ((IObjectContextAdapter) context).ObjectContext.Refresh(RefreshMode.ClientWins, col);

该行可以正常检索添加的实体或更改的实体。

我也无法处理 DbContext 以获取新实体,因为我的 DbContext 还带有另一个实体,并且重新加载它们会太长(我知道我没有遵循这样的规则:DbContext 应该用作跨国对象)

最佳答案

您可以“清除”Local收集并随后重新加载它:

foreach (var x in context.Set<X>().Local.ToList())
{
Entry(x).State = EntityState.Detached;
}
context.Set<X>().Load();

你不能做 context.Set<X>().Local.Clear(); ,因为这会将集合中的所有项目标记为 Deleted并且不会重新加载项目。

(礼貌 Code First: problem with Local collection)。

关于.net - 在数据库中删除行后更新 DbSet.Local,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19662194/

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