【代码】Lambda分组取最新时间数据

// 数据
List<LoginRecord> records = new List<LoginRecord>() {
                new LoginRecord(){ Id=1,Name="张三",LoginTime = DateTime.Now.AddDays(-6) },
                new LoginRecord(){ Id=2,Name="李四",LoginTime = DateTime.Now.AddDays(-3) },
                new LoginRecord(){ Id=3,Name="王五",LoginTime = DateTime.Now.AddDays(-2) },
                new LoginRecord(){ Id=4,Name="张三",LoginTime = DateTime.Now.AddDays(-1) },
                new LoginRecord(){ Id=5,Name="李四",LoginTime = DateTime.Now.AddDays(-4) },
            };

//第一种 分组后排序分组数据取第一个
records.GroupBy(g => g.Name).Select(p => p.OrderByDescending(t => t.LoginTime).FirstOrDefault());

//第二种 分组后取分组数据中的时间与最大时间相等的数据
records.GroupBy(g => g.Name).Select(p => p.FirstOrDefault(t => t.LoginTime == p.Max(s => s.LoginTime)));

  

posted @ 2022-03-01 20:10  插秧小能手  阅读(1054)  评论(0编辑  收藏  举报