如何使用扩展方法形成第二个查询作为第一个查询。
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 }); 发布于 2009-12-08 17:22:18
试试这个:
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(...)发布于 2009-12-08 17:24:02
我觉得你需要:
var qry = cust.GroupBy(p => p.Customer)
.Select(grp => new { CKey = grp.Key, Count = grp.Count() });https://stackoverflow.com/questions/1868480
复制相似问题