3

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

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

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

该行在检索添加的实体或更改的实体时正常工作。

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

4

1 回答 1

4

您可以“清除”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并且不会重新加载这些项目。

(礼貌代码优先:本地集合的问题)。

于 2013-10-30T11:05:44.073 回答