C#Linq -Extension方法

Uda*_*ana 2 c# linq

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

1) var query = from cm in cust
               group cm by cm.Customer into cmr
               select (new { CKey = cmr.Key, Count = cmr.Count() });
Run Code Online (Sandbox Code Playgroud)

(第二个查询形式不正确)

2)    var qry = cust.GroupBy(p => p.Customer).
                Select(new { CKey = p.Key, Count = p.Count }); 
Run Code Online (Sandbox Code Playgroud)

Jon*_*eet 12

试试这个:

var query = cust.GroupBy(p => p.Customer)
                .Select(g => new { CKey = g.Key, Count = g.Count() });
Run Code Online (Sandbox Code Playgroud)

您也可以将此简化为对此GroupBy重载的单个调用:

var query = cust.GroupBy(p => p.Customer,
                         (key, g) => new { CKey = key, Count = g.Count() });
Run Code Online (Sandbox Code Playgroud)

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

我还将点移动到仍然使用的形式的第二行Select- 我发现这使得查询更容易阅读; 我通常排列点,例如

var query = foo.Where(...)
               .OrderBy(...)
               .GroupBy(...)
               .Select(...)
Run Code Online (Sandbox Code Playgroud)

  • 他的意思是将所有标签分开,例如.where.选择分开的行,以便它易于阅读:) (2认同)