首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >C# Linq -Extension方法

C# Linq -Extension方法
EN

Stack Overflow用户
提问于 2009-12-08 17:20:13
回答 2查看 5.6K关注 0票数 2

如何使用扩展方法形成第二个查询作为第一个查询。

代码语言:javascript
复制
1) var query = from cm in cust
               group cm by cm.Customer into cmr
               select (new { CKey = cmr.Key, Count = cmr.Count() });

(第二个查询格式不佳)

代码语言:javascript
复制
2)    var qry = cust.GroupBy(p => p.Customer).
                Select(new { CKey = p.Key, Count = p.Count }); 
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2009-12-08 17:22:18

试试这个:

代码语言:javascript
复制
var query = cust.GroupBy(p => p.Customer)
                .Select(g => new { CKey = g.Key, Count = g.Count() });

不过,您还可以将其简化为对this GroupBy overload的单个调用:

代码语言:javascript
复制
var query = cust.GroupBy(p => p.Customer,
                         (key, g) => new { CKey = key, Count = g.Count() });

请注意,我已经将第二行的lambda表达式的参数名更改为g --我相信这给您提供了更多的线索,您实际上是在查看一个组,而不是单个实体。

我还将点移到了仍然使用Select的形式的第二行--我发现这使得查询更容易阅读。

代码语言:javascript
复制
var query = foo.Where(...)
               .OrderBy(...)
               .GroupBy(...)
               .Select(...)
票数 12
EN

Stack Overflow用户

发布于 2009-12-08 17:24:02

我觉得你需要:

代码语言:javascript
复制
var qry = cust.GroupBy(p => p.Customer)
    .Select(grp => new { CKey = grp.Key, Count = grp.Count() });
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1868480

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档