当前位置:  开发笔记 > 编程语言 > 正文

C#LINQ查询 - 分组依据

如何解决《C#LINQ查询-分组依据》经验,为你挑选了1个好方法。

我很难理解如何构建LINQ查询来执行以下操作:

我有一个CallLogs表,我希望得到一个结果,表示持续时间最长的呼叫.

该行看起来像这样:

[ID] [RemoteParty] [持续时间]

同一个RemoteParty可以有多个行,每个行代表一个特定持续时间的调用.我想知道哪个RemoteParty的总持续时间最长.

使用LINQ,我得到了这个:

var callStats = (from c in database.CallLogs
                 group c by c.RemoteParty into d
                 select new
                 {
                      RemoteParty = d.Key,
                      TotalDuration = d.Sum(x => x.Duration)
                 });

所以现在我有一个分组结果,每个RemoteParty的总持续时间,但我需要最大的单个结果.

[DistinctRemoteParty1] [持续时间]

[DistinctRemoteParty2] [持续时间]

[DistinctRemotePartyN] [持续时间]

如何修改查询来实现这一目标?



1> tvanfosson..:

订购结果并返回第一个结果.

var callStats = (from c in database.CallLogs
                 group c by c.RemoteParty into d
                 select new
                 {
                      RemoteParty = d.Key,
                      TotalDuration = d.Sum(x => x.Duration)
                 });

callStats = callStats.OrderByDescending( a => a.TotalDuration )
                     .FirstOrDefault();

推荐阅读
mobiledu2402851323
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有