LINQ查詢簡單概述
學習LINQ時,經(jīng)常會遇到LINQ查詢問題,這里將介紹LINQ查詢問題的解決方法。
在之前的C#版中,開發(fā)者應(yīng)用許多不同的查詢語言來訪問不同的數(shù)據(jù)源。例如,要查詢一個XML文件,開發(fā)者會使用XPath,要查詢一個SQL數(shù)據(jù)庫,開發(fā)者將使用SQL。在過去這種方法十分有效,并且現(xiàn)在仍然是訪問各種數(shù)據(jù)的主要方法。但是,這種方法具有一些缺點。一個顯著的缺點在于:開發(fā)者必須以一種不同的語言,而非他們當前使用的語言(如SQL或XPath)來編寫查詢代碼。另一個缺點是,在執(zhí)行某些查詢語言,如SQL時,開發(fā)者必須編寫映射代碼將查詢結(jié)果轉(zhuǎn)化為可用的C#業(yè)務(wù)對象。
C#3.0推出一種稱之為語言集成查詢(LINQ)的新方法。應(yīng)用LINQ,開發(fā)者可以編寫出能夠搜索任何IEnumerable數(shù)據(jù)源的代碼。所以除了應(yīng)用TSQL訪問MS SQL數(shù)據(jù)庫,應(yīng)用XPath訪問XML文件外,他們還可以應(yīng)用LINQ。
下面的代碼(列表C)是一個LINQ查詢的例子,它返回所有OrderCount大于10的顧客:
- using System;
- using System.Query;
- using System.Collections.Generic;
- public class SampleClass
- {
- static void Main()
- {
- List customers = GetCustomers();
- //Write our query to retrieve customers who have more than
- // 10 orders.
- IEnumerable queryResult = from customer in customers
- where customer.OrderCount > 10
- orderbycustomer.ID
- select customer;
- }
- }
LINQ與SQL或XPath不同,LINQ查詢用C#,而非第三方語言編寫。這樣,查詢就不會出現(xiàn)類型問題,開發(fā)者也就沒有必要編寫映射代碼把查詢返回的數(shù)據(jù)轉(zhuǎn)化成C#對象,而由LINQ API自動處理映射。
基本上,在ORM解決方案中,LINQ對象用途很大。同樣,它的范圍也非常廣泛,有大量MSDM信息描述了它的功能。
【編輯推薦】