【代码】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)));

  


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM