zoukankan      html  css  js  c++  java
  • 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"]);
  • 相关阅读:
    jquery城市选择案例
    jquery点击回到页面顶部方法
    jquery动态创建表格
    myeclipse、eclipse中项目复制后(可能无法访问)注意事项 .
    Myeclipse如何整合tomcat
    Java学习路线图
    ftp
    用javascript实现简体和繁体字间的转换
    FTP远程命令集
    JDBC-ODBC桥乱码问题解决方案
  • 原文地址:https://www.cnblogs.com/meteortent/p/2330941.html
Copyright © 2011-2022 走看看