有啥办法直接对c#中的datatable使用sql语句进行筛选呢
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了有啥办法直接对c#中的datatable使用sql语句进行筛选呢相关的知识,希望对你有一定的参考价值。
datatable有select方法,请参考下面代码:
private void GetRowsByFilter()DataTable table = DataSet1.Tables["Orders"];
string expression;
expression = "Date > #1/1/00#";
DataRow[] foundRows;
foundRows = table.Select(expression);
for(int i = 0; i < foundRows.Length; i ++)
Console.WriteLine(foundRows[i][0]);
参考技术A 没有办法的,SQL只用于数据库,DATATABLE只是一个装数据的容器,自身不支持数据过滤筛选 参考技术B dt.select方法 参考技术C 建议学习下linq 虽然不能对datable进行筛选
但能把数据加载到泛型中筛选 非常快捷方便
对 DataTable 执行 sql 查询
【中文标题】对 DataTable 执行 sql 查询【英文标题】:perform sql query on DataTable 【发布时间】:2012-06-15 18:53:04 【问题描述】:我在 C# 中有一个从 SQL 服务器返回的 DataTable。我正在传递这个数据表来耦合单独的函数。
我可以直接向 DataTable 发送某种查询,而不是遍历所有记录吗?
例如
set|subset|value
1 |1 |40
1 |2 |30
1 |3 |35
2 |1 |10
2 |2 |15
2 |3 |20
我怎样才能执行SELECT DISTINCT SET FROM TABLE
之类的操作并获取值1
和2
【问题讨论】:
既然可以使用 LINQ,为什么还要在数据表上使用 SQL? 【参考方案1】:只需使用 LINQ,更简单。
var result = yourTable.AsEnumerable().Select(f => f.Field<int>("Set")).Distinct();
【讨论】:
.Select 作品,但 Linq 在令人敬畏的大名单中仅落后啤酒一位以上是关于有啥办法直接对c#中的datatable使用sql语句进行筛选呢的主要内容,如果未能解决你的问题,请参考以下文章
如何使用 SQL 命令从我的 DataTable 对象中使用 foreach-loop 更新 C# 中的 MS Access 数据库?