由于需要,在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..::.Object

Object,设置为计算结果。

以下示例,以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()的更多相关文章

  1. sql子查询 嵌套SELECT语句

    嵌套SELECT语句也叫子查询,一个 SELECT 语句的查询结果能够作为另一个语句的输入值.子查询不但能够出现在Where子句中,也能够出现在from子句中,作为一个临时表使用,也能够出现在sele ...

  2. linq to datatable 和lambda查询datatable

    用Linq查询DataTable static DataTable table = new DataTable(); static DataColumn dc = new DataColumn(); ...

  3. 子查询。ANY三种用法。ALL两种用法。HAVING中使用子查询。SELECT中使用子查询。

    子查询存在的意义是解决多表查询带来的性能问题. 子查询返回单行多列: ANY三种用法: ALL两种用法: HAVING中的子查询返回单行单列: SELECT中使用子查询:(了解就好,避免使用这种方法! ...

  4. Yii数据库子查询嵌入select中,而不是where条件语句中

    $subQuery = (new Query())->select('COUNT(*)')->from('user'); // SELECT `id`, (SELECT COUNT(*) ...

  5. 深入理解MySql子查询IN的执行和优化

    IN为什么慢? 在应用程序中使用子查询后,SQL语句的查询性能变得非常糟糕.例如: SELECT driver_id FROM driver where driver_id in (SELECT dr ...

  6. 读书笔记--SQL必知必会11--使用子查询

    11.1 子查询 查询(query),任何SQL语句都是查询.但此术语一般指SELECT语句. SQL还允许创建子查询(subquery),即嵌套在其他查询中的查询. 作为子查询的SELECT语句只能 ...

  7. SQL Server 数据库子查询基本语法

    一.SQL子查询语句 1.单行子查询        select ename,deptno,sal        from emp        where deptno=(select deptno ...

  8. Oracel_子查询

    SQL子查询 子查询语法 SELECT select_list FROM table WHERE expr operator (SELECT select_list FROM table) 子查询 ( ...

  9. MySQL 使用JOIN优化子查询

    1.数据准备 mysql> select * from student; +----+--------+----------+---------+-------------+ | id | na ...

随机推荐

  1. U3D sorting layer, sort order, order in layer, layer深入辨析

    1,layer是对游戏中所有物体的分类别划分,如UIlayer, waterlayer, 3DModelLayer, smallAssetsLayer, effectLayer等.将不同类的物体划分到 ...

  2. 解决 Cannot find OpenSSL's <evp.h>

    yum install openssl openssl-devel ln -s /usr/lib64/libssl.so /usr/lib/

  3. <实训|第二天>掌握linux6.7中安装vmware、vmware安装linux发行版本以及遇到的问题最后libreoffice的安装

    期待已久的linux运维.oracle"培训班"终于开班了,我从已经开始长期四个半月的linux运维.oracle培训,每天白天我会好好学习,晚上回来我会努力更新教程,包括今天学到 ...

  4. Linix常用命令

    uname -a    查看内核版本        ls -al    显示所有文件的属性 pwd         显示当前路径         cd -    返回上一次目录     cd ~    ...

  5. 【剑指Offer学习】【面试题60:把二叉树打印出多行】

    题目:从上到下按层打印二叉树,同一层的结点按从左到右的顺序打印,每一层打印一行. 解题思路 用一个队列来保存将要打印的结点.为了把二叉树的每一行单独打印到一行里,我们须要两个变量:一个变量表示在当前的 ...

  6. jquery 点击按钮实现listbox的显示与隐藏,点击其他地方按钮外的地方,隐藏listbox

    本来不知道如何获取服务器的控件的,这下知道可以这么做了,所以记录下来.... <asp:ImageButton ID="alltime" ImageUrl="ima ...

  7. js 通信

    js 页面间的通信 看了一下公司原来的代码,原页面ajax post返回一个页面完整的HTML,然后再打开一个新页面并输出ajax返回的所有代码到新页面上,在新页面上以表单提交的形式实现重定向. 任凭 ...

  8. 什么是网络套接字(Socket)?

    什么是网络套接字(Socket)?一时还真不好回答,而且网络上也有各种解释,莫衷一是.下文将以本人所查阅到的资料来说明一下什么是Socket. Socket定义 Socket在维基百科的定义: A n ...

  9. 【Android】AndroidManifest 中original-package标签

    Manifest.xml 中   <manifest>标签中package属性用于设置应 用程序的进程名,即在运行时使用ddms查看到的进程名.   <original-packag ...

  10. 实验二Java面向对象程序设计_20135129李畅宇

    ava第二次实验报告   课程:Java实验   班级:201352     姓名:池彬宁  学号:20135212 成绩:             指导教师:娄佳鹏   实验日期:15.05.05 ...