LINQ访问DataTable

简介:
一般的来说,你不能直接使用Linq查询DataSet/DataTable/DataRowCollection等等。例如下面这条语句,将不能运行:
var q=from r in table.Rows select r;
你可以添加下面这个类来转换相关的数据类型用作Linq查询:
// simple wrapper that implements IEnumerable<T>
internal class LinqList<T>: IEnumerable<T>, IEnumerable
{
    IEnumerable items;

    internal LinqList(IEnumerable items)
    {
        this.items = items;
    }

    #region IEnumerable<DataRow> Members
    IEnumerator<T> IEnumerable<T>.GetEnumerator()
    {
        foreach (T item in items)
        yield return item;
    }

    IEnumerator IEnumerable.GetEnumerator()
    {
        IEnumerable<T> ie = this;
        return ie.GetEnumerator();
    }
    #endregion
}
下面是一个使用该方法的实例:
// 创建一个DataTable
DataTable table = new DataTable();
table.Columns.Add("Id", typeof(int));
table.Rows.Add(new object[]{1});
table.Rows.Add(new object[]{2});
table.Rows.Add(new object[]{3});

// 将DataTable.Rows用上面的这个类进行封装
LinqList<DataRow> rows = new LinqList<DataRow>(table.Rows);

// 执行一条查询的示例
IEnumerable<DataRow> selectedRows = from r in rows
    where (int)r["Id"] == 2
    select r;

// 输出查询结果
foreach (DataRow row in selectedRows)
    Console.WriteLine(row["Id"]);

本文转自lidup 51CTO博客,原文链接:http://blog.51cto.com/lidup/156117,如需转载请自行联系原作者

相关文章
|
3月前
|
SQL 开发框架 .NET
聊聊 System.Linq.Dynamic,以及分享一个使用 System.Linq.Dynamic 扩展 LINQ 查询的详细例子
聊聊 System.Linq.Dynamic,以及分享一个使用 System.Linq.Dynamic 扩展 LINQ 查询的详细例子
107 0
|
存储 .NET
突然发现 ViewState,Linq 水火不容
刚才在写一个小东西,突然发现一个问题。很奇怪,希望大家能帮忙解决一下   我用WebForm+Linq 做一个小网站,在读取数据的时候,我想将Linq 读取出来的泛型集合缓存起来。大家自然想到asp.net中的几个内置对象来存储。
806 0
|
.NET 索引 开发框架
|
.NET 数据库 Windows
|
存储 .NET 开发框架
Linq to Entity调用存储过程【转】
http://www.cnblogs.com/chenxizhang/archive/2010/01/03/1638201.html学习交流群:364976091
838 0