如何使用扩展方法将第二个查询形成为第一个查询。
1) var query = from cm in cust
group cm by cm.Customer into cmr
select (new { CKey = cmr.Key, Count = cmr.Count() });
(第二个查询格式不正确)
2) var qry = cust.GroupBy(p => p.Customer).
Select(new { CKey = p.Key, Count = p.Count });
答案 0 :(得分:12)
试试这个:
var query = cust.GroupBy(p => p.Customer)
.Select(g => new { CKey = g.Key, Count = g.Count() });
您也可以将此简化为this GroupBy
overload的单次调用:
var query = cust.GroupBy(p => p.Customer,
(key, g) => new { CKey = key, Count = g.Count() });
请注意,我已将第二行的lambda表达式参数名称的名称更改为g
- 我相信这给出了更多的线索,表明您真正关注的是群组而不是单个实体
我还将点移动到仍然使用Select
的表单中的第二行 - 我发现这使查询更容易阅读;我通常排列点,例如
var query = foo.Where(...)
.OrderBy(...)
.GroupBy(...)
.Select(...)
答案 1 :(得分:2)
我认为你需要:
var qry = cust.GroupBy(p => p.Customer)
.Select(grp => new { CKey = grp.Key, Count = grp.Count() });