DataTable中数据记录的排序,检索,合并,分页,统计

一、排序
1 获取DataTable的默认视图
2 对视图设置排序表达式
3 用排序后的视图导出的新DataTable替换就DataTable
(Asc升序可省略,多列排序用","隔开)

DataView dv = dt.DefaultView;
dv.Sort = "id Asc,name Desc";
dt = dv.ToTable();

二、检索
1 设置查询字符串
2 使用Select方法获取到所有满足条件的数据行对象数组
(多项查询条件间,用and隔开.模糊查询使用 like %)
DataRow[] matches = dt.Select("(id<'003') and (name='名字11') and (number like '%2007%')");
string strName = matches[0]["name"].ToString();

三、合并
假定有2个DataTable:Dt1 , Dt2。表结构一样
将Dt2接在Dt1后可采用此方法
dt1.Merge(dt2);

四、分页
PagedDataSource pds = new PagedDataSource();
pds.AllowPaging = true;
pds.DataSource = dvIntegralExpense;
pds.AllowPaging = true;
pds.PageSize = pager.PageSize;
pds.CurrentPageIndex = pager.PageIndex;

rptIntegralExpense.DataSource = pds;
rptIntegralExpense.DataBind();
五:
我们在使用Sql Server这些数据库时,可以轻松的通过Sum、Aver、Count等统计出相关结果,那么,在已经把数据检索出来的 DataSet(DataTable)中呢?特别是通过Web Service获得了DataSet,这个时候,可是没有办法回头去修改Select语句来获取这些统计了。那么在DataSet/DataTable中 是否可以进行统计呢?答案是肯定的。
在MSDN中,有一篇MS推荐的统计方法,就是逐行对数据进行求和统计,这个方法,其实有等于无(或许这个方法只是针对于DataGrid求取小计用 吧),因为这个方法中采用的是DataGrid的ItemDataBind事件来对数据进行累加,同我们手动写代码统计没有什么区别。
本文介绍一个简单的方法,不需要逐条记录进行计算就可以轻松的获得DataTable中的记录统计结果。这个简单的方法就是调用功能强大的 DataTable的函数Compute。
一、调用说明(仅以C#为例,下同):
public object Compute(string strExpression,string strFilter)
参数:
strExpression:要计算的表达式字符串,基本上类似于Sql Server中的统计表达式
strFilter:统计的过滤字符串,只有满足这个过滤条件的记录才会被统计
二、调用举例:
以下示例,假设一个产品销售表table,描述某商场中各促销员销售的实际记录,包含字段为:姓名(Name)、性别(Sex,0为女,1为男)、生日 (Birthday)、销售产品的代码(ProID)、销售的数量(Quantity)、销售价格(Price)。
1.统计所有性别为女的销售员的数量:
table.Compute("Count(*)","Sex=0");
2.统计所有销售员中年龄大于20岁的
table.Compute("Count(*)","Birthday<'"+today);//today为今天的日期字符串
3.统计销售产品的平均价格
table.Compute("Aver(Price)","true");
4.统计产品代码为1的产品销售数量:
table.Compute("Sum(Quantity)","ProID=1");
5.统计所有产品的销售总金额:
要统计总销售金额,由于table中不存在某项产品某个促销员销售的金额数据,但我们可以通过Quantity*Price来获得。比如:
table.Compute("Sum(Quantity*Price)","true");
这里一个问题是:DataTable的统计功能没有SqlServer强,这个统计是错误的,因为Compute的统计不具备 Sum(Quantity*Price)这样数据的功能。那怎么办呢?
对于这样复杂数据的统计,我们可以在DataTable中创建一个新的字段来完成,比如Amount,同时设置该字段的Expression为 Quantity*Price,这样我们就可以使用统计功能了:
table.Compute("Sum(Amount)","true");

转载于:https://www.cnblogs.com/yexinw/archive/2012/09/25/2701713.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在处理dataTable数据时,可以采取以下几个步骤: 1. 数据读取:首先,你需要将数据从源文件读取到dataTable。这可以通过使用适当的数据读取函数或库来实现,具体取决于你使用的编程语言和数据格式。 2. 数据清洗:一旦数据被读取到dataTable,你可能需要对数据进行清洗,以去除无效或重复的数据,处理缺失值或异常值,并将数据转换为适合进一步分析或处理的格式。 3. 数据转换:根据你的需求,你可能需要对dataTable数据进行转换。这包括将字符串转换为日期或数字格式,将数据进行分组或聚合,以及创建新的派生变量。 4. 数据筛选:如果你只对dataTable的特定数据子集感兴趣,你可以使用筛选条件来选择满足条件的行或列。这可以通过使用逻辑运算符和比较操作符来实现。 5. 数据排序:如果你希望按照特定的标准对dataTable数据进行排序,你可以使用排序函数或方法来实现。你可以指定要排序的列以及升序或降序排序的顺序。 6. 数据分析:一旦数据准备好,你可以使用适当的分析函数或方法来探索和分析dataTable数据。这可能包括计算统计指标、绘制图表或执行其他数据分析任务。 以上是处理dataTable数据的一般步骤,具体的实现取决于你使用的编程语言和数据处理工具。希望对你有所帮助!如果你有任何进一步的问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值