DataTable的子查询--DataTable.Select()
由于需要,在sql查询获得结果集之后,又需要对该结果再进行筛选一次,若重新从sql中查询会浪费资源,因此特地去查阅了一些资料,学会了用DataTable进行子查询。
在.Net Framework 2.0里,我们可以直接利用DataTable的Select()方法进行子查询,十分方便。
DataTable dt = new DataTable(); //假设dt是由"SELECT ID,Name,Sex,Age FROM Customer_Info"查询出来的结果
现在我们需要再进行筛选,
1.假如我们需要 性别为男 的客户信息
DataRow[] drNew= dt.Select("Sex=’男’");//查询
2.假如我们需要 名字里带有“生” 的客户信息
DataRow[] drNew = dt.Select("Name LIKE ’%杨%’");//模糊查询
3.假如我们需要 年龄大于15且结果按照姓名升序年龄降序 的客户信息
DataRow[] drNew = dt.Select("Age > 15", "Name asc,Age desc");//查询+排序
4.假如我们要取结果中第15-20条记录,做法如下:
DataTable dtNew = dt.Clone();
DataRow[] drNew= dt.Select();//获得所有行
for(int i=14;i<20;i++)
{
dtNew.ImportRow(drNew[i]);
}
如果要把DataRow赋值给新的DataTable,怎么赋值呢?
DataTable dtNew = dt.Clone();
for (int i = 0; i < drNew.Length; i++)
{
dtNew.Rows.Add(drNew[i]);
}
但这样程序就会出错,说该DataRow是属于其他DataTable的,那要怎么做呢?很简单,这样就可以解决了:
DataTable dtNew = dt.Clone();
for (int i = 0; i < drNew.Length; i++)
{
dtNew.ImportRow(drNew[i]);
}
这样就OK了,是不是很方便。
以上便是刚刚学的一点DataTable子查询。
以下是网上的一些资源,还没用过,先记录下来:
有一个简单的方法,可以轻松的获得DataTable中的记录统计结果。这个简单的方法就是调用功能强大的DataTable的函数Compute。
函数如下
public Object Compute(
string expression,
string filter
)
参数
expression
类型:System..::.String参数需要聚合函数,要计算的表达式字符串,基本上类似于Sql Server中的统计表达式
filter
类型:System..::.String要限制在表达式中进行计算的行的筛选器。 统计的过滤字符串,只有满足这个过滤条件的记录才会被统计,也就是确定在表达式中使用哪些行
返回值
类型:System..::.ObjectObject,设置为计算结果。
以下示例,以SQL-Server数据库中的Northwind数据库中的Orders数据表,描述订单信息,包含字段为:订单号 (OrderID)、客户编号(CustomerID)、职工编号(EmployeeID)、订货时间(OrderDate)、船号(ShipVia)、 运费(Freight)。
1.统计所有职工编号EmployeeID为5的数量:
table.Compute("Count(*)","EmployeeID=5");
2.统计所有运费Freight中运费大于100的个数
table.Compute("Count(*)","Freight>100'");
3.统计运费Freight的平均值
table.Compute("Aver(Freight)","true");
4.统计职工编号EmployeeID为5的运费总额:
table.Compute("Sum(Freight)"," EmployeeID=5");
以上都是计算每一列的合计,那么要添加一行求合计可以使用下面的方法:
//创建一个数据集
DataSet customers = new DataSet();
//在数据集中添加一个名称为CustomersTable的数据表
DataTable customersTable = customers.Tables.Add("CustomersTable");
//创建一个新行并添加到CustomersTable数据表中
DataRow dataRow = new DataRow();
dataRow= customersTable.NewRow();
//然后就是统计了,声明连个int 变量i:循环变量, colCnt: customersTable表中的列数
int i ;
int colCnt ;
colCnt = customersTable.Cols.Count;
for( i=0 ;i< colCnt -1;i++)
//求第i列的和并且结果赋值给新的dataRow数据行
dataRow(i)= customersTable.Compute("Sum("+i.ToString()+")","true");
//把数据行添加到customersTable数据表中
customersTable.Rows.Add(dataRow);
DataTable的子查询--DataTable.Select()的更多相关文章
- sql子查询 嵌套SELECT语句
嵌套SELECT语句也叫子查询,一个 SELECT 语句的查询结果能够作为另一个语句的输入值.子查询不但能够出现在Where子句中,也能够出现在from子句中,作为一个临时表使用,也能够出现在sele ...
- linq to datatable 和lambda查询datatable
用Linq查询DataTable static DataTable table = new DataTable(); static DataColumn dc = new DataColumn(); ...
- 子查询。ANY三种用法。ALL两种用法。HAVING中使用子查询。SELECT中使用子查询。
子查询存在的意义是解决多表查询带来的性能问题. 子查询返回单行多列: ANY三种用法: ALL两种用法: HAVING中的子查询返回单行单列: SELECT中使用子查询:(了解就好,避免使用这种方法! ...
- Yii数据库子查询嵌入select中,而不是where条件语句中
$subQuery = (new Query())->select('COUNT(*)')->from('user'); // SELECT `id`, (SELECT COUNT(*) ...
- 深入理解MySql子查询IN的执行和优化
IN为什么慢? 在应用程序中使用子查询后,SQL语句的查询性能变得非常糟糕.例如: SELECT driver_id FROM driver where driver_id in (SELECT dr ...
- 读书笔记--SQL必知必会11--使用子查询
11.1 子查询 查询(query),任何SQL语句都是查询.但此术语一般指SELECT语句. SQL还允许创建子查询(subquery),即嵌套在其他查询中的查询. 作为子查询的SELECT语句只能 ...
- SQL Server 数据库子查询基本语法
一.SQL子查询语句 1.单行子查询 select ename,deptno,sal from emp where deptno=(select deptno ...
- Oracel_子查询
SQL子查询 子查询语法 SELECT select_list FROM table WHERE expr operator (SELECT select_list FROM table) 子查询 ( ...
- MySQL 使用JOIN优化子查询
1.数据准备 mysql> select * from student; +----+--------+----------+---------+-------------+ | id | na ...
随机推荐
- HADOOP命令介绍
一.用户命令1.archive命令 (1).什么是Hadoop archives?Hadoop archives是特殊的档案格式.一个Hadoop archive对应一个文件系统目录. Hadoop ...
- 浅谈android binder机制
binder机制 是谷歌优化在android上更适合终端的IPC(多进程通信方式),满足系统对通信方式,传输性能和安全性的要求. 特性: 1. 用驱动程序来推进进程间的通信.2. 通过共享内存来提高性 ...
- windows server 2003(64位)上利用iis6部署32位应用
如果直接部署,会出现如下问题: 试图加载格式不正确的程序. (Exception from HRESULT: 0x8007000B) 解决办法 1.命令行键入: cscript.exe %SYSTEM ...
- [Docker] Docker简介
一.简介 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化.容器是完全使用沙箱机制,相互之间 ...
- first Automation
//创建一个容器 CEmbWordCntrItem * pItem = NULL; CEmbWordDoc * pDoc = GetDocument(); pItem = new C ...
- 在引用KindEditor编辑器时,运行时出现以下错误:错误46 找不到类型或命名空间名称“LitJson”(是否缺少 using 指令或程序集引用?)
将asp.net下bin文件夹下的文件LitJSON.dll拷贝到工程的bin目录下,并在工程中添加引用 在后台加入: using LitJson;
- 3level_menus
# encoding: utf-8 # Creator:耿亚月 Creation time:2017-1-2 # Modifier:耿亚月 Modification time:2017-1-2 #输入 ...
- Jenkins构建时报错:No Space left on device
Jenkins在自动化构建服务的同时也在消耗服务器的磁盘空间,如果构建的项目个数很多,而Jenkins 服务器磁盘空间又不是非常大的话,每隔一段时间磁盘空间就会爆满导致,就会出现磁盘空间不足无法构建的 ...
- JS数组常用函数以及查找数组中是否有重复元素的三种常用方法
阅读目录: DS01:常用的查找数组中是否有重复元素的三种方法 DS02:常用的JS函数集锦 DS01.常用的查找数组中是否有重复元素的三种方法 1. var ary = new Array(&qu ...
- AndroidManifest.xml file missing!
1.点击菜单栏中的Project——>Clean一下. 2.把AndroidManifest.xml文件再保存一下就可以了.