一般的来说,你不能直接使用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"]);