C# DataTable使用Linq查询详解

devtools/2024/11/19 1:09:42/

前奏- C# 对DataTable进行查询

C# 可以对 DataTable 进行查询。在 .NET 框架中,DataTable 类提供了几种方法来查询数据,包括 Select 方法和 AsEnumerable 扩展方法(在 System.Data.DataSetExtensions 命名空间中)。

使用 Select 方法 

DataTable table = new DataTable();// 假设 DataTable 已经被填充了数据// 使用 Select 方法进行查询
DataRow[] rows = table.Select("Column1 = 'SomeValue'");foreach (DataRow row in rows)
{// 处理每一行
}

使用 LINQ (Language Integrated Query)

using System.Data;
using System.Linq;DataTable table = new DataTable();// 假设 DataTable 已经被填充了数据// 使用 LINQ 进行查询
var query = from row in table.AsEnumerable()where row.Field<string>("Column1") == "SomeValue"select row;foreach (var row in query)
{// 处理每一行
}

 或者使用方法语法:

var query = table.AsEnumerable().Where(row => row.Field<string>("Column1") == "SomeValue");foreach (var row in query)
{// 处理每一行
}

 注意

使用 LINQ 查询 DataTable,性能可能会比直接使用 Select 方法稍慢,因为 LINQ 查询会被转换为 Select 方法的调用,并且在某些情况下,LINQ 查询可能会涉及到额外的内存分配。然而,LINQ 提供了更灵活和强大的查询能力,并且代码通常更易于阅读和维护。

 DataTable使用Linq查询详解

基础概念 

在开始之前,你需要了解几个基本概念:

  • DataTable.AsEnumerable(): 这个方法将 DataTable 转换为 IEnumerable<DataRow>,使其可以使用 LINQ 查询。
  • DataRow.Field<T>(string columnName): 这个扩展方法用于安全地获取 DataRow 中指定列的值,并转换为指定的类型。

 基本查询步骤

以下是使用 LINQ 查询 DataTable 的基本步骤:

  1. 转换 DataTable: 使用 AsEnumerable() 将 DataTable 转换为可查询的形式。
  2. 定义查询: 使用 LINQ 方法(如 WhereSelectOrderBy 等)定义查询。
  3. 执行查询: 使用 foreach 循环或其他迭代方法来执行查询并处理结果。

示例

假设我们有一个 DataTable,其中包含以下列:IdNameAge

1. 筛选数据

筛选年龄大于 30 的记录: 

using System;
using System.Data;
using System.Linq;DataTable table = new DataTable();
// 假设 DataTable 已经被填充了数据var filteredRows = table.AsEnumerable().Where(row => row.Field<int>("Age") > 30);foreach (var row in filteredRows)
{Console.WriteLine($"Id: {row["Id"]}, Name: {row["Name"]}, Age: {row["Age"]}");
}

 2. 排序数据

按年龄升序排序: 

var sortedRows = table.AsEnumerable().OrderBy(row => row.Field<int>("Age"));foreach (var row in sortedRows)
{Console.WriteLine($"Id: {row["Id"]}, Name: {row["Name"]}, Age: {row["Age"]}");
}

 3. 选择特定列

选择 Name 和 Age 列: 

var selectedColumns = table.AsEnumerable().Select(row => new { Name = row.Field<string>("Name"), Age = row.Field<int>("Age") });foreach (var item in selectedColumns)
{Console.WriteLine($"Name: {item.Name}, Age: {item.Age}");
}

 4. 聚合操作

计算所有人的年龄总和: 

var totalAge = table.AsEnumerable().Sum(row => row.Field<int>("Age"));Console.WriteLine($"Total Age: {totalAge}");

 5. 分组操作

按年龄分组并计算每个年龄组的人数: 

var groupedByAge = table.AsEnumerable().GroupBy(row => row.Field<int>("Age")).Select(group => new { Age = group.Key, Count = group.Count() });foreach (var group in groupedByAge)
{Console.WriteLine($"Age: {group.Age}, Count: {group.Count}");
}

 


http://www.ppmy.cn/devtools/135076.html

相关文章

hadoop分布式文件系统常用命令

前言 搭建完hadoop后&#xff0c;会生成一个hdfs的分布式文件系统。HDFS是一个逻辑上的文件系统&#xff0c;它存储在Hadoop集群的多个节点上&#xff0c;而不是单个机器的本地磁盘上。 常用命令 # 创建目录&#xff0c;-p参数可以创建所有必需的父目录&#xff08;按照层级…

Day43 | 动态规划 :状态机DP 买卖股票的最佳时机买卖股票的最佳时机II

Day43 | 动态规划 &#xff1a;状态机DP 买卖股票的最佳时机&&买卖股票的最佳时机II 动态规划应该如何学习&#xff1f;-CSDN博客 本次题解参考自灵神的做法&#xff0c;大家也多多支持灵神的题解 买卖股票的最佳时机【基础算法精讲 21】_哔哩哔哩_bilibili 动态规…

JAVA开源项目 微服务在线教育系统 计算机毕业设计

博主说明&#xff1a;本文项目编号 T 060 &#xff0c;文末自助获取源码 \color{red}{T060&#xff0c;文末自助获取源码} T060&#xff0c;文末自助获取源码 目录 一、系统介绍二、演示录屏三、启动教程四、功能截图五、文案资料5.1 选题背景5.2 国内外研究现状5.3 可行性分析…

搭建Spring gateway网关微服务

在使用微服务架构时&#xff0c;往往我们需要搭建一个网关服务&#xff0c;作为各个微服务的统一入口。Spring gateway作为网关服务的后起之秀&#xff0c;受到各大企业的欢迎。下面介绍下网关服务Spring gateway的搭建。 引入依赖&#xff0c;这一步比较重要&#xff0c;也需要…

前端无感刷新token

摘要&#xff1a; Axios 无感知刷新令牌是一种在前端应用中实现自动刷新访问令牌&#xff08;access token&#xff09;的技术&#xff0c;确保用户在进行 API 请求时不会因为令牌过期而中断操作 目录概览 XMLHttpRequestAxiosFetch APIJQuni.request注意事项&#xff1a; 访问…

Nature Communications 基于触觉手套的深度学习驱动视触觉动态重建方案

在人形机器人操作领域&#xff0c;有一个极具价值的问题&#xff1a;鉴于操作数据在人形操作技能学习中的重要性&#xff0c;如何有效地从现实世界中获取操作数据的完整状态&#xff1f;如果可以&#xff0c;那考虑到人类庞大规模的人口和进行复杂操作的简单直观性与可扩展性&a…

Python爬虫----python爬虫基础

一、python爬虫基础-爬虫简介 1、现实生活中实际爬虫有哪些&#xff1f; 2、什么是网络爬虫&#xff1f; 3、什么是通用爬虫和聚焦爬虫&#xff1f; 4、为什么要用python写爬虫程序 5、环境和工具 二、python爬虫基础-http协议和chrome抓包工具 1、什么是http和https协议…

简单的爬虫脚本编写

一、数据来源分析 想爬取一个网站的数据&#xff0c;我们首先要进行数据分析。通过浏览器F12开发者工具栏进行抓包&#xff0c;可以分析我们想要的数据来源。 通过关键字搜索&#xff0c;可以找到相对应的数据包 二、爬虫实现 需要用到的模块为&#xff1a;request&#xf…