C# linq lambda 分组获取最新的数据

Posted study10000

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C# linq lambda 分组获取最新的数据相关的知识,希望对你有一定的参考价值。

1、linq 写的不是很好总结一下

    ①、数据

 var id = Guid.Parse("04245059-9251-44e1-4c16-08d6be4a0add");
            Guid id2 = Guid.Parse("12385059-9251-44e1-4c16-08d6be4a0add");

            var time = DateTime.Now;
            var time2 = time.AddHours(5);
            List<list_data> list = new List<list_data>()
            {
                new list_data (){  id=id,name="1三",time=time,flag="sun" },
                new list_data (){  id=id,name="1四",time=time, flag="moon" },
                new list_data (){  id=id,name="1五",time=time, flag="star" },
                new list_data (){  id=id,name="1六",time=time.AddDays(1),flag="moon" },
                new list_data (){  id=id,name="1七",time=time.AddDays(1),flag="sun" },
                new list_data (){  id=id,name="1九",time=time.AddDays(1),flag="star" },
                new list_data (){  id=id2,name="2九",time=time2,flag="sun" },
                new list_data (){  id=id2,name="2四",time=time2, flag="moon" },
                new list_data (){  id=id2,name="2五",time=time2, flag="star" },
                new list_data (){  id=id2,name="2六",time=time2.AddDays(1),flag="moon" },
                new list_data (){  id=id2,name="2七",time=time2.AddDays(1),flag="sun" },
                new list_data (){  id=id2,name="2三",time=time2.AddDays(1),flag="star" }
            };

  ②、linq

  var query = list.AsQueryable();
            var data = from item in query
                       orderby item.time descending
                       group item by new { item.id ,item.time}
                       into g_data//根据id、time分成4组
                       group g_data by g_data.Key.id into last_data
                       select last_data;//根据id分成2组【1组里面又包含2组】获取第一组

  ③、lambda

  var lambda = query.OrderByDescending(p => p.time).GroupBy(g => new { g.id, g.time })
                      .GroupBy(g => g.Key.id).FirstOrDefault();

2、第二种

   var data2 = from item in query
                        group item by new { item.id, item.flag }
                        into g_data
                        select g_data.OrderByDescending(p => p.time).FirstOrDefault()//根据id、flag分成6组获取每组第一个【凑成一个组】
                        into datas group datas by datas.id//根据id分组分成两组
                        into  last_data select last_data;

 

以上是关于C# linq lambda 分组获取最新的数据的主要内容,如果未能解决你的问题,请参考以下文章

c# linq groupby是默认去掉重复行吗

通过 linq 对实体查询进行分组,以通过加入表来获取具有最新时间戳的一条记录

如何解决 C# 中 linq 的 lambda 表达式中的对象引用错误?

使用 Linq C# 获取元组对象列表中的最新日期对象

.NET(C#) System.Linq中实现多列group by(分组)的示例代码

具有潜在分组层的 C# LINQ 问题