使用DbSet<> .Local进行分页

时间:2013-08-02 10:59:09

标签: wpf entity-framework entity-framework-5 observablecollection dbset

我正在尝试在WPF应用程序中分页数据集。

我的服务方法如下:

public ObservableCollection<MyModel> GetPageOfModels(int projectId, int numSkip, int numResults)
{
  this.db.Set<MyModel>()
    .Where(x => x.Project.Id == projectId)
    .OrderBy(x => x.Name)
    .Skip(numSkip)
    .Take(numResults)
    .Load();

  return this.db.Set<MyModel>().Local;
}

第一次被击中时效果很好。但是当我移到另一个页面时,Load() 下一页添加到该集合中,而不是替换它。

如果我在每次调用GetPageOfModels之前重新创建数据上下文,它就可以工作,但我需要保留相同的数据上下文。有没有办法实现这个目标?

1 个答案:

答案 0 :(得分:1)

如果您必须保留上下文,那么您可以在下一页之前分离所有内容。

foreach(var entity in db.Set<MyModel>().Local.ToList())
   db.Entry(entity).State = EntityState.Detached;
相关问题