【发布时间】:2019-01-10 00:04:49
【问题描述】:
我有两列 Date 和 PersonInCharge,我想按日期降序对列表进行排序,然后返回唯一没有重复的人名的列表。我使用Distinct() 过滤最终名单,但我不知道为什么列表顺序总是按字母顺序而不是降序。
到目前为止,这是我的代码:
IList<string> model.StaffNames = await _context.FarmDiary
.Select(f => new { f.PersonInCharge, f.Date })
.OrderByDescending(x => x.Date)
.Select(x => x.PersonInCharge)
.Distinct()
.ToListAsync();
【问题讨论】:
-
如果这是解析为某些 SQL 命令的 Linq2Entities,它是纯自然的,因为顺序语句总是出现在任何不同或分组之后。无论如何,语句的顺序很大程度上取决于底层的 linq-provider。对于 Linq2Objects,应该保留顺序。
-
在大多数 DBMS 中 distinct 是通过排序和与以前的比较来实现的,这意味着 distinct 可能会推翻您之前所做的任何排序。提供者的一种合理方法是在 .Distinct() 调用之前忽略所有排序(因为 .net .Distinct() 不保证保留顺序,或者它们甚至不会不一致)
-
执行的查询被简化为
SELECT DISTINCT PersonInCharge FROM FarmDiary。由于 distinct 可以使用索引来加快查询速度,因此结果的顺序将取决于可用的索引(原因参见其他 cmets)。
标签: c# entity-framework linq