理解IQueryable的最簡單方式就是,把它看做一個查詢,在執行的時候,將會生成結果序列。html
LINQ to SQL能夠將查詢表達式轉換爲SQL語句,而後在數據庫中執行。相比LINQ to Object,則是將查詢表達式直接轉化爲Enumerable的一系列方法,最終在C#內部執行。LINQ to Object的數據源老是實現IEnumerable<T>(因此不如叫作LINQ to IEnumerable<T>),相對的,LINQ to SQL的數據源老是實現IQueryable<T>並使用Queryable的擴展方法。數據庫
將查詢表達式轉換爲SQL語句並不保證必定能夠成功。編程
大部分LINQ語句是在最終結果的第一個元素被訪問的時候(即在foreach中調用MoveNext方法)才真正開始運算的,這個特色稱爲延遲執行。通常來講,返回另一個序列(一般爲IEnumerable<T>或IQueryable<T>)的操做,使用延遲執行,而返回單一值的運算,使用當即執行。數組
Select方法不會觸發LINQ的執行。一些觸發的方式是:編程語言
1. LINQ的讀法:(1)lin k (2)lin q
post
2. LINQ的關鍵詞:from, select, in, where, group by, order by …
測試
3. LINQ的注意點:必須以select或者是group by 結束。
ui
4. LINQ的語義:
url
from 臨時變量 in 集合對象或數據庫對象
spa
where 條件表達式
[order by條件]
select 臨時變量中被查詢的值
[group by 條件]
LINQ的查詢返回值的類型是臨時變量的類型,多是一個對象也多是一個集合。而且LINQ的查詢表達式是在最近一次建立對象時才被編譯的。LINQ的查詢通常跟var關鍵字一塊兒聯用 (什麼是var?匿名對象) 。如下的兩個查詢表達式是同樣的效果:
var q = from name in methods
where (name.Name.Length > 15)
select name;
5. LINQ的全稱:Language-Integrated Query
6. LINQ的分類:LINQ to Object, LINQ to XML, LINQ to SQL, LINQ to ADO.NET
C#3.0 LINQ 查詢語法
首先來看一個很簡單的LINQ查詢例子,查詢一個int 數組中小於5的數字,並按照大小順序排列:
class Program
{
static void Main(string[] args)
{
int[] arr = new int[] { 8, 5, 89, 3, 56, 4, 1, 58 };
var m = from n in arr where n < 5 orderby n select n;
foreach (var n in m)
{
Console.WriteLine(n);
}
Console.ReadLine();
}
}
上述代碼除了LINQ查詢語法外,其餘都是咱們所熟悉的語法,而LINQ查詢語法跟SQL查詢語法很相識,除了前後順序。
Q:爲什麼 LINQ 查詢語法是以 from 關鍵字開頭的,而不是以 select 關鍵字開頭的?select 開頭這種寫法跟SQL的寫法更接近,更易懂呀?
A:簡單來講,爲了IDE的智能感知(Intelisence)這個功能,select 關鍵字放在後面了。
編程語言以 select 開頭寫LINQ查詢語法不是沒出現過,你若是使用過2005年的VB9 CTP 版本,那時候VB9的LINQ查詢語法就是 select 關鍵字在前面,可是 select 關鍵字在前面,在作智能感知(Intelisence)時候就很頭大。通過微軟IDE組的權衡,肯定了把 from 關鍵字放在最前面。
好比:你看 http://blog.joycode.com/saucer/archive/2005/09/16/63513.aspx 這篇博客,那時候 VB9 LINQ的查詢語法仍是 select 參數在最前面。不事後來 VB9 測試版改爲了跟 C# 同樣的作法, from 關鍵字放在最前面了。
更詳細的解釋,來自裝配腦殼
假設你要書寫這樣的代碼:Select p.Name, p.Age From p In persons Where xxx ,代碼是一個個字符輸入的。
咱們在寫到 p in persons 以前,p 的類型是沒法推測的,因此寫 Select p. 的時候,Name之類的屬性不會彈出智能提示來。
這樣就須要先去寫 From 這句,再回來寫 Select。
微軟IDE組通過反覆考慮決定,還不如就把 Select 寫到後面了。因而編程語言中的寫法就肯定這樣來寫了。
VB9 的這個變化能夠參看這篇博客:
Select/From vs. From/Select revisited...
咱們再來看一個稍稍複雜的LINQ查詢:
在咱們羅列的語言字符串中,咱們但願按照字符長短,分類羅列出來,實現代碼以下:
static void Main(string[] args)
{
string [] languages = {"Java","C#","C++","Delphi","VB.net","VC.net","C++ Builder","Kylix","Perl","Python"};
var query = from item in languages
orderby item
group item by item.Length into lengthGroups
orderby lengthGroups.Key descending
select lengthGroups;
foreach (var item in query)
{
Console.WriteLine("strings of length ",item.Key);
foreach (var val in item)
{
Console.WriteLine(val);
}
}
Console.ReadLine();
}
其中的 into 關鍵字表示 將前一個查詢的結果視爲後續查詢的生成器,這裏是跟 group by 一塊兒使用的。
LINQ中的Group by不要跟 SQL 中的Group by 混淆,SQL 因爲是二維結構,Group by 的一些邏輯受二維結構的約束,沒法象 LINQ 中的Group by 這麼靈活。