[英]Is LINQ extension method Where guaranteed to preserve order?
如果我在发布/订阅架构中有一个消息列表,我认为使用 IEnumerable.Where 在底层列表上检索特定消息并信任消息的顺序是合理的?
Enumerable.Where
扩展方法会,但Queryable.Where
扩展方法不会。
Enumerable.Where
必须保留顺序,因为它流式传输结果并且没有缓存(并且缓存结果中没有逻辑)。
另一方面, Queryable.Where
将给定的调用转换为底层数据源可以理解的内容,并且无法保证排序。 在使用关系数据库时,可以很容易地观察到这种效果。 添加where
子句可以让数据库选择另一个索引,这可以改变结果的顺序。 如果没有明确的order by
子句,所选索引通常将决定结果的排序。
对于 Linq to Objects / IEnumerable
这是正确的 - 将维护顺序 - 对于IQueryable
提供程序,它取决于提供程序,许多提供程序不维护顺序。
看起来这个事实(维护订单)没有记录在 MSDN 上,所以我认为它是一个实现细节 - 尽管不太可能 - 将来可能会改变。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.