C#在DataTable中使用LINQ

來源:互聯網
上載者:User

標籤:data   uil   enum   elf   ril   c#   visual   name   order   

LINQ 查詢適用於實現的資料來源 IEnumerable<T>介面或System.Query.IQueryable介面。 

DataTable類預設是沒有實現以上介面的。

所以要在DataTable中使用LINQ查詢,需要調用一下AsEnumerable方法,返回一個EnumerableRowCollection<DataRow>集合。

這樣我們就可以在DataTable中使用LINQ查詢了

首先建立測試資料

 1 private static DataTable GetStuTable() 2         { 3  4             int[] id = { 4, 5, 1, 3, 2, 7, 6 }; 5             string[] name = {"Tom","Jack","HelloWorld","Visual Studio","Gril","Timmy","Geo" }; 6             DataTable table = new DataTable("Student"); 7             table.Columns.Add("ID", typeof(int)); 8             table.Columns.Add("Name", typeof(string)); 9 10             for(int i = 0;i< id.Length;i++)11             {12                 table.Rows.Add(new object[] { id[i],name[i]});13             }14 15             return table;16         }

1、使用LINQ對DataTable進行排序

 1 DataTable dt = GetNumbersTable(); 2  3             var students = dt.AsEnumerable(); 4  5             //排序 6             var result = students.OrderBy(x => x.Field<int>("ID")); 7  8             //輸出 9             Console.WriteLine("ID" + "\t" + "Name");10             foreach (DataRow row in result)11             {12                 Console.WriteLine(row["ID"].ToString() + "\t" + row["Name"].ToString());13             }

運行結果如下

 

C#在DataTable中使用LINQ

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.