如何使用c#LINQ在分组结果中选择所需的行

时间:2011-12-19 18:31:26

标签: c# linq

我有一个像这样的客户表

ID EndDate 
1  2/11/2010
1  3/14/2011
2  5/3/2011
2  12/1/2011
3  4/5/2010

我想为每个ID组取最大日期的行 结果是这样的:

ID EndDate
1  3/14/2011
2  12/1/2011
3  4/5/2010

如何在c#中使用一个流畅的语法(没有循环或第二个语句)来获得结果?

Customers.GroupBy( c => c.ID ).....//How do I proceed?

1 个答案:

答案 0 :(得分:5)

您可以使用:

var results = Customers.GroupBy(c => c.ID)
                       .Select(
                          g => g.OrderByDescending(c => c.EndDate).First() );