DataTable中数据记录的统计
来源:互联网 发布:淘宝乐高店铺推荐 编辑:程序博客网 时间:2024/06/11 20:39
本文介绍一个简单的方法,不需要逐条记录进行计算就可以轻松的获得DataTable中的记录统计结果。这个简单的方法就是调用功能强大的DataTable的函数Compute。
一、调用说明(仅以C#为例,下同):
public object Compute(string strExpression,string strFilter)
参数:
strExpression:要计算的表达式字符串,基本上类似于Sql Server中的统计表达式
strFilter:统计的过滤字符串,只有满足这个过滤条件的记录才会被统计
二、调用举例:
1。统计所有性别为女的销售员的数量:
table.Compute("Count(*)","Sex=0");//不能为*,需为一字段名
2。统计所有销售员中年龄大于20岁的
table.Compute("Count(*)","Birthday<'"+today);//today为今天的日期字符串
3。统计销售产品的平均价格
table.Compute("avg(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");
以上都是计算每一列的合计,要添加一行求合计可以使用下面的方法:
System.Data.DataRow dataRow=dataSet.Tables[0].NewRow()
'假设你的DataSet为dataSet,表在索引0位置,同时假设你的所有字段都是可以求合计的。
System.DataRow dataRow = new System.DataRow();
dataRow=DT.NewRow();
然后就是统计了:
int i ;
int fldCnt ;
fldCnt=DT.Cols.Count;
for( i=0
DT.Rows.Add(dataRow);
- DataTable中数据记录的统计
- DataTable中数据记录的统计
- DataTable中数据记录的统计
- DataTable中数据记录的统计
- DataTable中数据记录的统计
- DataTable中数据记录的统计
- DataTable中数据记录的统计
- DataTable中数据记录的统计
- DataTable中数据记录的统计
- DataTable中数据记录的统计
- DataTable中数据记录的统计-- Compute的强大
- DataTable中数据记录的排序、检索、合并、分页、统计
- DataTable中数据记录的排序,检索,合并,分页,统计
- DataTable中数据记录的排序、检索、合并、分页、统计
- DataTable中数据记录的统计 选择自 triout 的 Blog
- DataTable创建、数据的添加及数据记录的排序,检索,合并,分页,统计(整理)
- DataTable用中使用Compute 实现简单的DataTable数据的统计.....
- DataTable用中使用Compute 实现简单的DataTable数据的统计
- cloudera impala安装完整版
- Python IDLE快捷键
- 浅谈C++容器(五) .
- android 4.0.4的默认壁纸的修改
- bundle开发----串口通讯
- DataTable中数据记录的统计
- js中,json转string
- 添加一个视图
- MapReduce源码分析总结
- how to install/uninstall a dll to GAC
- HoSaNIC
- 成为优秀程序员的10点建议
- phonegap+jquerymobile:页面跳转出现白屏的解决方案
- 公众气象服务平台