有啥办法直接对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 之类的操作并获取值12

【问题讨论】:

既然可以使用 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 数据库?

对 DataTable 执行 sql 查询

Flutter:有啥办法可以改变DataTable的行线颜色?

C#操作sql查询出的临时表,详细如下:

循环删除DataTable.Row中的多行问题

C#里通过button按钮来查询SQL中的表