【实例应用】DATATable那些事儿

2024-05-25 11:58
文章标签 应用 实例 事儿 datatable

本文主要是介绍【实例应用】DATATable那些事儿,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

      这几天做成绩分析,天天跟DataTable混在一起,应用了其众多属性和方法。今天,就来八一八DataTable那些常用的方法。


一、去除重复行的操作

   在项目中,经常会对表进行固定列的去重操作,此方法就是去除PaperID和PaperName的重复行,并返回这两列:

DataTable dtOld = DataTable();    
//…
DataView myDataView = new DataView(dtOld);//去掉重复行的DataView,dtOld为需要转换的表
DataTable dtDistinct = myDataView.ToTable(true, new string[] { "PaperID", "PaperName" });//DataView的ToTable(true,字段)方法是去掉重复的数据
//第一个参数,true 去除重复,false 不去除//第二个参数, 需要显示并去重的字段,这里用的paperID和PaperName


二、合并两个结构相同的表

   dtOld,dtNew分别是两个结构相同的非空表,把两个表合并成一个表为:

//Merge dtOld into dtNew
dtNew.Merge(dtOld);


三、DataTable进行数据统计

   我们可以轻松的使用SQL Sever进行数据统计,同样,也可以对检索出来的DataTable进行数据统计,我们可以通过函数Compute进行统计。

   1、函数说明

   public object Compute(string strExpression,string strFilter);

   strExpression:要计算的表达式字符串,基本上类似于Sql Server中的统计表达式。

   strFilter:统计的过滤字符串,只有满足这个过滤条件的记录才会被统计。

   

   2、实例

   假设得到如下表dtSport:

   


   1)统计所有得分为零的数量:

   object n=dtSport.Compute("count(ID)","Score=0");


   2)统计各项的平均得分

   decimal averScore=Convert.ToDecimal(dtSport.Compute("avg(Score)","true"));


   3)所有项目的总分

   int intAll = Convert.ToInt32(dtSport.Compute("sum(Score)","true"));


四、动态筛选信息并添加到新表中

   已知datatable表dtSport(如上图),在此以筛选得分大于2分的记录为例:

DataTable dtFilter = new DataTable();
dtFilter = dtSport.Clone();    //得到数据结构和dtSport相同的表
//dtSport.Copy();     得到和dtSport相同的表for (int i = 0; i < dtSport.Rows.Count; i++)
{DataRow[] dr = dtSport.Select("Score>'2' ");if (dr != null && dr.Length > 0){//显示有记录dtFilter.ImportRow(dr[0]);    //得到满足条件的datatable  dtFilter}
}

   DataTable还有许多常用的方法,在此就不一一举例了,熟练的掌握这些方法,能让我们更快更好的完成学习任务,在实践中慢慢积累吧。

 





   

这篇关于【实例应用】DATATable那些事儿的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1001444

相关文章

PostgreSQL简介及实战应用

《PostgreSQL简介及实战应用》PostgreSQL是一种功能强大的开源关系型数据库管理系统,以其稳定性、高性能、扩展性和复杂查询能力在众多项目中得到广泛应用,本文将从基础概念讲起,逐步深入到高... 目录前言1. PostgreSQL基础1.1 PostgreSQL简介1.2 基础语法1.3 数据库

MySQL的配置文件详解及实例代码

《MySQL的配置文件详解及实例代码》MySQL的配置文件是服务器运行的重要组成部分,用于设置服务器操作的各种参数,下面:本文主要介绍MySQL配置文件的相关资料,文中通过代码介绍的非常详细,需要... 目录前言一、配置文件结构1.[mysqld]2.[client]3.[mysql]4.[mysqldum

Python中的filter() 函数的工作原理及应用技巧

《Python中的filter()函数的工作原理及应用技巧》Python的filter()函数用于筛选序列元素,返回迭代器,适合函数式编程,相比列表推导式,内存更优,尤其适用于大数据集,结合lamb... 目录前言一、基本概念基本语法二、使用方式1. 使用 lambda 函数2. 使用普通函数3. 使用 N

Python中yield的用法和实际应用示例

《Python中yield的用法和实际应用示例》在Python中,yield关键字主要用于生成器函数(generatorfunctions)中,其目的是使函数能够像迭代器一样工作,即可以被遍历,但不会... 目录python中yield的用法详解一、引言二、yield的基本用法1、yield与生成器2、yi

Python多线程应用中的卡死问题优化方案指南

《Python多线程应用中的卡死问题优化方案指南》在利用Python语言开发某查询软件时,遇到了点击搜索按钮后软件卡死的问题,本文将简单分析一下出现的原因以及对应的优化方案,希望对大家有所帮助... 目录问题描述优化方案1. 网络请求优化2. 多线程架构优化3. 全局异常处理4. 配置管理优化优化效果1.

从基础到高阶详解Python多态实战应用指南

《从基础到高阶详解Python多态实战应用指南》这篇文章主要从基础到高阶为大家详细介绍Python中多态的相关应用与技巧,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、多态的本质:python的“鸭子类型”哲学二、多态的三大实战场景场景1:数据处理管道——统一处理不同数据格式

Java Stream流以及常用方法操作实例

《JavaStream流以及常用方法操作实例》Stream是对Java中集合的一种增强方式,使用它可以将集合的处理过程变得更加简洁、高效和易读,:本文主要介绍JavaStream流以及常用方法... 目录一、Stream流是什么?二、stream的操作2.1、stream流创建2.2、stream的使用2.

springboot项目中集成shiro+jwt完整实例代码

《springboot项目中集成shiro+jwt完整实例代码》本文详细介绍如何在项目中集成Shiro和JWT,实现用户登录校验、token携带及接口权限管理,涉及自定义Realm、ModularRe... 目录简介目的需要的jar集成过程1.配置shiro2.创建自定义Realm2.1 LoginReal

Python跨文件实例化、跨文件调用及导入库示例代码

《Python跨文件实例化、跨文件调用及导入库示例代码》在Python开发过程中,经常会遇到需要在一个工程中调用另一个工程的Python文件的情况,:本文主要介绍Python跨文件实例化、跨文件调... 目录1. 核心对比表格(完整汇总)1.1 自定义模块跨文件调用汇总表1.2 第三方库使用汇总表1.3 导

Java Stream 的 Collectors.toMap高级应用与最佳实践

《JavaStream的Collectors.toMap高级应用与最佳实践》文章讲解JavaStreamAPI中Collectors.toMap的使用,涵盖基础语法、键冲突处理、自定义Map... 目录一、基础用法回顾二、处理键冲突三、自定义 Map 实现类型四、处理 null 值五、复杂值类型转换六、处理