首页 > 其他分享 >DataTable中数据记录的排序,检索,合并,分页,统计(整理)(转)

DataTable中数据记录的排序,检索,合并,分页,统计(整理)(转)

时间:2022-09-19 09:58:42浏览次数:80  
标签:检索 Compute Price pds table 排序 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语句来获取这些统计了。那么在DataSe

 

t/DataTable中是否可以进行统计呢?答案是肯定的。
 
  在MSDN中,有一篇MS推荐的统计方法,就是逐行对数据进行求和统计,这个方法,其实有

 

等于无(或许这个方法只是针对于DataGrid求取小计用吧),因为这个方法中采用的是DataGri

 

d的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强,这个统计是错误的,因为Compu

 

te的统计不具备Sum(Quantity*Price)这样数据的功能。那怎么办呢?
  
  对于这样复杂数据的统计,我们可以在DataTable中创建一个新的字段来完成,比如Amount

 

,同时设置该字段的Expression为Quantity*Price,这样我们就可以使用统计功能了:
  table.Compute("Sum(Amount)","true");

https://www.cnblogs.com/Elong/archive/2007/07/03/804264.html

标签:检索,Compute,Price,pds,table,排序,DataTable,统计
From: https://www.cnblogs.com/xihong2014/p/16706697.html

相关文章

  • 1636. 按照频率将数组升序排序【模拟】
    题目给你一个整数数组nums,请你将数组按照每个值的频率升序排序。如果有多个值的频率相同,请你按照数值本身将它们降序排序。请你返回排序后的数组。难度:简单提示:......
  • 034每个进程占用内存排序
    一、  #ps-aux|head-n2  USERPID%CPU%MEMVSZRSSTTYSTATSTARTTIMECOMMAND  root10.00.019633213704?......
  • [算法]循环排序
    这类题的特点是给定的数值和下表rank是类似的,其中可能会有一些差异.在设计算法的时候,可以将value值映射到rank上去.其中,选择大于的值最好比rank的最大值+1,这样会避......
  • 1636. 按照频率将数组升序排序
    1636.按照频率将数组升序排序给你一个整数数组 nums ,请你将数组按照每个值的频率升序排序。如果有多个值的频率相同,请你按照数值本身将它们降序排序。 请你返......
  • 选择排序
    有五个数12,-1,66,5,7,选出最大的的数的下标,把最大的数与最后的位置交换,5个数找4次最大的数即可代码如下  1#include<stdio.h>2#include<math.h>3intmain()......
  • 冒泡降序排序
    假设有5个数12,-1,66,5,7解:存进一个长度为5的数组,依次比较前后两项,前<后即可交换代码如下  1#include<stdio.h>2intmain(){3inta[5]={12,-1,66,5,7};4......
  • 排序的模板
    只是按照理论搞了一下,连变量名都懒得开全,我相信他过不了编译,所以不保证正确性,不过可以表示各种排序算法的大概原理?**code#include<bits/stdc++.h>usingnamespacest......
  • Day_1(并查集朋友圈、字典序排序)
    1.并查集朋友圈:找出最多的一个圈子内有多少用户!id[](表示当前节点的父节点)nodeNum[](表示当前节点为根的那一组节点数量)importjava.util.Scanner;//并查集class......
  • map遍历、map排序
    //map遍历Map<Integer,Integer>map=newHashMap<Integer,Integer>();map.put(1,2);//1.entrySet遍历,在键和值都需要时使用(最常用)......
  • 【笔记】拓扑排序(Ⅱ)
    题单0X00P7860[COCI2015-2016#2]ARTUR好题。首先考虑本题与拓扑排序有和关系。可以想到,某些棍子的先后移动顺序是有限制的。比如:这里红色的必须比蓝色的先移动,因为......