C# 对DataTable中按条件进行筛选和更新。
当我们频繁的对数据库进行操作时,可能造成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中按条件进行筛选和更新。的更多相关文章
- 关于c#在DataTable中根据条件删除某一行
我们经常会将数据源放在DataTable里面,但是有时候也需要移除不想要的行,下面的代码告诉你们 DataTable dts: DataRow[] foundRow; ...
- mysql中运用条件判断筛选来获取数据
### part1 单表查询 sql查询完整语法: select .. from .. where .. group by .. having .. order by .. limit .. 一.wh ...
- [datatable]关于在DataTable中执行DataTable.Select("条件")返回DataTable的解决方法
-- :09关于在DataTable中执行DataTable.Select("条件")返回DataTable的解决方法 在实际编程工程中,常常遇到这样的情况:DataTable并不 ...
- C#如何对DataTable中的数据进行条件搜索
经常遇到将数据库中的数据读取到DataTable中的时候再次对DataTable进行条件筛选,下面的筛选的一个例子: DataRow[] dr = dt.Select("token = '& ...
- 在DataTable中执行DataTable.Select("条件")返回DataTable;
转:http://blog.csdn.net/hcf_force/article/details/7779062 1.在DataTable中执行DataTable.Select("条件&qu ...
- 在DataTable中执行DataTable.Select("条件")
.在DataTable中执行DataTable.Select("条件")返回DataTable: // <summary> // 执行DataTable中的查询返回 ...
- DataTable中执行DataTable.Select("条件"),
我们在使用Sql ******这些数据库时,可以轻松的通过Sum.Aver.Count等统计出相关结果,那么,在已经把数据检索出来的DataSet(DataTable)中呢?特别是通过Web Serv ...
- python基础一 -------如何在列表字典集合中根据条件筛选数据
如何在列表字典集合中根据条件筛选数据 一:列表 先随机生成一个列表,过滤掉负数 1,普通for循环迭代判断 2,filter()函数判断,filter(函数,list|tuple|string) fi ...
- python数据结构-如何在列表、字典、集合中根据条件筛选数据
如何在列表.字典.集合中根据条件筛选数据 问题举例: 过滤列表[1, 2, 5, -1, 9, 10]中的负数 筛选字典{“zhangsan”:97, "lisi":80, &qu ...
随机推荐
- dialog更新数据
将数据显示在最上面
- 03-树2 List Leaves(25 point(s)) 【Tree】
03-树2 List Leaves(25 point(s)) Given a tree, you are supposed to list all the leaves in the order of ...
- linux iptables:安全应用,防火墙
iptables:安全应用,防火墙 windows和linux都有防火墙,企业的边缘会部署防火墙保证企业内部的局域网是安全的.针对个人电脑会有防火墙保证系统是安全的. 防火墙是唯一通道. 防火墙分类( ...
- [coci2011]友好数对 容斥
无趣的小x在玩一个很无趣的数字游戏.他要在n个数字中找他喜欢友好数对.他对友好数对的定义是:如果有两个数中包含某一个以上相同的数位(单个数字),这两个数就是友好数对.比如:123和345 就是友好数对 ...
- Appium——连接真机,adb devices获取不到设备号
连接真机后,使用 adb devices获取不到设备号. 1.检查usb接口是否正常,是否正常链接到电脑 2.手机开发者模式是否开启,usb调试是否开启 3.检查驱动是否正常 4.如果驱动显示黄叹号, ...
- 【Selenium】跳转问题
/** * rewrite the get method, adding user defined log</BR> * 地址跳转方法,使用WebDriver原生get方法,加入失败重试的 ...
- python之yield和Generator
首先我们从一个小程序导入,各定一个list,找出其中的素数,我们会这样写 import math def is_Prims(number): if number == 2: return True / ...
- 在CentOs6.x 安装Cx_oracle5.x
Setting up anything Oracle related is a huge pain. After hunting the web for info with minimal succe ...
- 51nod最长递增路径:(还不错的图)
一个无向图,可能有自环,有重边,每条边有一个边权.你可以从任何点出发,任何点结束,可以经过同一个点任意次.但是不能经过同一条边2次,并且你走过的路必须满足所有边的权值严格单调递增,求最长能经过多少条边 ...
- ubuntu下网络性能测试
iperf的主要功能 TCP 测量网络带宽 报告MSS/MTU值的大小和观测值 支持TCP窗口值通过套接字缓冲 当P线程或Win32线程可用时,支持多线程.客户端与服务端支持同时多重连接 UDP 客户 ...