C# linq group by的运用

 在工作中程序需要对查询出来数据List进行进一步处理时,Linq的能力就体现出来了。例如以下一段代码,它的意思是对list按照ZG_ID, ZG_IDNAME, ZG_NO, CARD_NO进行分组求和后赋值到disZg,这个变量的数据组成就是select new{}中的内容,接下来就可以对disZg进行进一步分析操作了。

 var disZg = from tt in list
 where tt.ZG_ID > 0
 group tt by new { tt.ZG_ID, tt.ZG_IDNAME, tt.ZG_NO, tt.CARD_NO }
 into qq
 select new
 {
   ZG_ID = qq.Key.ZG_ID,
   ZG_IDNAME = qq.Key.ZG_IDNAME,
   ZG_NO = qq.Key.ZG_NO,
   CARD_NO = qq.Key.CARD_NO,
   DX_AMOUNT = qq.Sum(p => p.DX_AMOUNT),
   NBJF_AMOUNT = qq.Sum(p => p.NBJF_AMOUNT),
   ZG_TYPE_IDNAME = qq.Max(p => p.ZG_TYPE_IDNAME),
   POST_ID = qq.Max(p => p.POST_ID),
   DEPT_IDNAME = qq.Max(p => p.DEPT_IDNAME)
 };

 

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
C#使用LINQ进行分组(group by)操作有多种方式。引用和引用展示了两种常见的方法。 第一种方法是使用LINQ查询表达式。在查询表达式中,我们可以使用`group by`子句来指定要分组的属性,然后使用`into`子句将结果存储在一个临时变量中。下面是一个示例: ```csharp var results = from p in persons group p.car by p.PersonId into g select new { PersonId = g.Key, Cars = g.ToList() }; ``` 在这个示例中,我们将`persons`集合按照`PersonId`属性进行分组,并将每个分组的`car`属性收集到一个列表中。结果将包含每个分组的`PersonId`和对应的`Cars`列表。 第二种方法是使用LINQ的函数形式。在函数形式中,我们可以使用`GroupBy`方法,该方法接受三个参数:分组的属性、分组的元素和一个选择器函数。此外,我们还需要使用`ToList`方法将结果转换为列表。下面是一个示例: ```csharp var results = persons.GroupBy(p => p.PersonId, p => p.car, (key, g) => new { PersonId = key, Cars = g.ToList() }); ``` 这个示例与前面的查询表达式示例的功能相同。我们通过`PersonId`属性进行分组,将每个分组的`car`属性收集到一个列表中,并创建一个包含`PersonId`和`Cars`属性的匿名对象。 总而言之,以上就是在C#使用LINQ进行分组操作的两种常见方法。您可以根据个人喜好和项目需求选择适合的方法。引用提供了更多关于C#使用LINQ的`GroupBy`操作的详细信息和示例,供您进一步了解和学习。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [C#Linq中的GroupBy](https://blog.csdn.net/q__y__L/article/details/125997669)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [C#LINQ使用GroupBy](https://download.csdn.net/download/weixin_38610717/12721697)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yxlalm

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值