c# – 如何使用linq对数据表中的多个列进行分组?

参见英文答案 > Group By Multiple Columns                                    13个
我正在使用Linq对我的数据表中的某些列进行分组

List<DataTable> tables = ds
  .Tables[0]
  .AsEnumerable()
  .GroupBy(row => row.Field<string>("EMAIL"),row.Field<string>("NAME"))
  .Select(g => g.copyToDataTable())
  .ToList();

我收到一个构建错误“当前上下文中不存在名称’行’”?如何处理多个组?

解决方法

使用匿名对象:

List<DataTable> tables = ds.Tables[0].AsEnumerable()
                           .GroupBy(row => new {
                               Email = row.Field<string>("EMAIL"),Name = row.Field<string>("NAME") 
                           }).Select(g => g.copyToDataTable()).ToList();

相关文章

目录简介使用JS互操作使用ClipLazor库创建项目使用方法简单测...
目录简介快速入门安装 NuGet 包实体类User数据库类DbFactory...
本文实现一个简单的配置类,原理比较简单,适用于一些小型项...
C#中Description特性主要用于枚举和属性,方法比较简单,记录...
[TOC] # 原理简介 本文参考[C#/WPF/WinForm/程序实现软件开机...
目录简介获取 HTML 文档解析 HTML 文档测试补充:使用 CSS 选...