我正在尝试在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
之前重新创建数据上下文,它就可以工作,但我需要保留相同的数据上下文。有没有办法实现这个目标?
答案 0 :(得分:1)
如果您必须保留上下文,那么您可以在下一页之前分离所有内容。
foreach(var entity in db.Set<MyModel>().Local.ToList())
db.Entry(entity).State = EntityState.Detached;