7

我想添加一些排序到一个EntityCollection绑定到一个ItemsControl(在xaml中)。我也想尽可能简单地做到这一点。看来,这是不可能的。排序EF4 EntityCollection的最简单方法是什么?<T>?

如果我将该集合包裹在实体内的集合属性的“已排序”版本中,我会丢失集合更改通知。我无法使用CollectionViewSource,因为实体集合的BindingListCollectionView不支持排序的一些该死的原因(说明:我见过与“脏”黑客的博客帖子来解决这个问题,所以请不要回答那个kthx)。

是否有一个简单的(几行xaml,几行代码,不管)的方式来实现这个?

回答

3

无法直接过滤或排序EntityCollection类型。这是一个常见的LINQ-to-Entities问题,请参阅: Sort child objects while selecting the parent using LINQ-to-Entities

一个解决方案是在需要数据时使用LINQ分别对实体集合进行排序,并产生额外的性能影响。如果您正在处理一个您希望较小和/或较少使用的集合,那么处理时间的差异可以忽略不计。

如果希望数据库执行排序并使用任何索引,则可以将主实体与子实体一起投影。 Alex James在他的MSDN博客中发布了一个示例:http://blogs.msdn.com/b/alexj/archive/2009/02/25/tip-1-sorting-relationships-in-entity-framework.aspx。当然,您不仅限于匿名类型。

相关问题