当我们频繁的对数据库进行操作时,可能造成CPU使用率过高,这时我们可以先将数据表读取到DataTable,然后在必要的时候再更新到数据库中。
以下是DataTable中对数据的选择和更新操作。采用DataTable.Select()方法。采用该方法获取的结果是DataRow对象数组。Select()有三种重载(以下资料来自MSDN):
MSDN关于Select()方法内容链接

以下依次进行说明:
1.Select() 获取DataTable中的所有行,转换成DataRow的格式。这里不做过多说明,以下对dtTest(非空的DataTable)使用Select()

DataRow[] rows = dtTest.Select();
1
2.Select(String expression) 如以下例子所示,expression代表筛选的表达式(sql语句where之后的部分),但不包含排序方式。

DataRow[] rows = dtTest.Select("id<5");
1
3.Select(String expression , String sortOrder ) 其中sortOrder 代表排序方式(字段名称+正序或者倒序)。

DataRow[] rows = dtTest.Select("id<5","id ASC");
1
4.DataTable.Select (String expression , String sortOrder , DataViewRowState dVRState) 其中dVRState代表这一个数据集合的状态。枚举类型。详细内容可参考以下链接:
DataViewState详细介绍

DataRow[] rows = dtTest.Select("id<5","id ASC",DataViewRowState.Added);
1
!!!更新DataTable
有了以上的基础我们即可以根据条件轻松的获取DataTable中的想要的内容了。只不过通过Select()方法获取的结果是DataRow[ ]形式,如果需要将其转换为DataTable格式,可采用如下的方法(全是自己码的,觉得好用给我点个赞,^_^):

//建立一张数据表
DataTable dtInitial = new DataTable("Orders");
dtInitial.Columns.Add("id", typeof(Int32));
dtInitial.Columns.Add("name", typeof(string));

//向表中添加数据
for (int i = 0; i < 10; i++)
{
DataRow newRow = dtInitial.NewRow();
newRow["id"] = i;
newRow["name"] = "未命名";
dtInitial.Rows.Add(newRow);
}
//更新表的条件
string expression = "id < 5 ";
//要更新的字段
string variable = "name";
//更新字段的值
string value = "Clear_mind";
//不重复字段
string primaryKey = "id";

DataTable dtReturn = null; //用于返回结果的DataTable
DataRow[] arrRow = dtInitial.Select(expression); //选出满足更新条件的行
dtReturn = arrRow[0].Table.Clone(); //复制需要更新的表的结构

bool[] rowChanged = new bool[dtInitial.Rows.Count]; //用于保存修改的行的索引号
for (int i = 0; i < dtInitial.Rows.Count; i++)
{
rowChanged[i] = false;
}

//将修改的行存入dtReturn
foreach (DataRow row in arrRow)
{
row[variable] = value; //将要更新的值写入需要更新的行的对应字段
for (int i = 0; i < dtInitial.Rows.Count; i++)
{
//找到修改过的行
if (dtInitial.Rows[i][primaryKey].ToString() == row[primaryKey].ToString())
{
dtReturn.ImportRow(row); //将修改过的行存入dtReturn
rowChanged[i] = true; //将修改过的行号对应的标志位置1
break;
}
}

}

//将未修改的行存入dtReturn
for (int i = 0; i < dtInitial.Rows.Count; i++)
{
if (rowChanged[i] == false)
dtReturn.ImportRow(dtInitial.Rows[i]);
}
//打印结果
for (int i = 0; i < dtReturn.Rows.Count; i++)
{
Console.WriteLine(dtReturn.Rows[i]["name"].ToString());
}
---------------------
作者:DurableHumor
来源:CSDN
原文:https://blog.csdn.net/my_clear_mind/article/details/79673205
版权声明:本文为博主原创文章,转载请附上博文链接!

C# 对DataTable中按条件进行筛选和更新。的更多相关文章

  1. 关于c#在DataTable中根据条件删除某一行

    我们经常会将数据源放在DataTable里面,但是有时候也需要移除不想要的行,下面的代码告诉你们 DataTable dts:                DataRow[] foundRow;   ...

  2. mysql中运用条件判断筛选来获取数据

    ### part1 单表查询 sql查询完整语法: select .. from .. where .. group by .. having .. order by .. limit .. 一.wh ...

  3. [datatable]关于在DataTable中执行DataTable.Select("条件")返回DataTable的解决方法

    -- :09关于在DataTable中执行DataTable.Select("条件")返回DataTable的解决方法 在实际编程工程中,常常遇到这样的情况:DataTable并不 ...

  4. C#如何对DataTable中的数据进行条件搜索

    经常遇到将数据库中的数据读取到DataTable中的时候再次对DataTable进行条件筛选,下面的筛选的一个例子: DataRow[] dr = dt.Select("token = '& ...

  5. 在DataTable中执行DataTable.Select("条件")返回DataTable;

    转:http://blog.csdn.net/hcf_force/article/details/7779062 1.在DataTable中执行DataTable.Select("条件&qu ...

  6. 在DataTable中执行DataTable.Select("条件")

     .在DataTable中执行DataTable.Select("条件")返回DataTable:  // <summary> // 执行DataTable中的查询返回 ...

  7. DataTable中执行DataTable.Select("条件"),

    我们在使用Sql ******这些数据库时,可以轻松的通过Sum.Aver.Count等统计出相关结果,那么,在已经把数据检索出来的DataSet(DataTable)中呢?特别是通过Web Serv ...

  8. python基础一 -------如何在列表字典集合中根据条件筛选数据

    如何在列表字典集合中根据条件筛选数据 一:列表 先随机生成一个列表,过滤掉负数 1,普通for循环迭代判断 2,filter()函数判断,filter(函数,list|tuple|string) fi ...

  9. python数据结构-如何在列表、字典、集合中根据条件筛选数据

    如何在列表.字典.集合中根据条件筛选数据 问题举例: 过滤列表[1, 2, 5, -1, 9, 10]中的负数 筛选字典{“zhangsan”:97, "lisi":80, &qu ...

随机推荐

  1. Exam 70-762 Developing SQL Databases

    这个考试还是很有用的,教了很多有用的东西,不错,虽然考试需要很多钱,不过值的尝试.虽然用了sql server 这么多年但是对于事务.多并发的优化还是处于小学生的水平,通过这次考试争取让自己提一个档次 ...

  2. 动态区间第K大

    整体二分. 主要需要注意的一点是,对于每个删除操作,若删除操作被算入贡献,则最开始的插入操作也一定会被算入,所以不必担心删除删错. #include<cstdio> #include< ...

  3. APP测试走过的那些坑

    我现在的工作有一大部分也是app测试,虽然自己是app开发出身,但是在测试上还是跌入了很多大坑,毕竟二者还是有很大不同,所处的角度也是不一样的.而开发转测试中,我认为较难的也是一个角度的转换,以一个开 ...

  4. 写给精明Java开发者的测试技巧

    我们都会为我们的代码编写测试,不是吗?毫无疑问,我知道这个问题的答案可能会从 “当然,但你知道怎样才能避免写测试吗?” 到 “必须的!我爱测试”都有.接下来我会给你几个小建议,它们可以让你编写测试变得 ...

  5. 精选Java面试题

    什么是隐式类型转换?什么是显示类型转换? 当将占位数少的类型赋值给占位数多的类型时,Java自动使用隐式类型转换(如int型转为long型).当把在级别高的变量的值赋给级别底变量时,必须使用显示类型转 ...

  6. (转)使用cygwin注意事项一

    原文出处:http://gotgit.readthedocs.io/en/latest/01-meet-git/050-install-on-windows-cygwin.html 在Windows下 ...

  7. Can't locate Log/Dispatch.pm in @INC

    记录一下配置mha的时候遇到的错误,使用perl模块发送邮件的时候报以下错误: # masterha_check_ssh --conf=/data/mha/app1.cnf Can't locate ...

  8. Vue 变化检测问题

    受现代Javascript的限制,Vue不能检测到对象属性的添加和删除,因为Vue在初始化时将属性转为getter/setter,所以属性必须在data对象上才能让Vue转换它,Vue不允许在已经创建 ...

  9. Redis配置主从架构,实现读写分离

    Redis的主从架构,能帮助我们实现读多,写少的情况,下面配置Redis架构,很简单. 准备环境 vmware + rhel-server-7.0(101,102,103)+redis-3.2.0 1 ...

  10. jquery : eval() 解析json的注意

    jquery eval解析JSON中的注意点介绍 来在:http://www.jb51.net/article/40842.htm 在JS中将JSON的字符串解析成JSON数据格式,一般有两种方式: ...