口試Linq題 LINQ to SQL與IQueryable

LINQ to SQL與IQueryable

理解IQueryable的最簡單方式就是,把它看做一個查詢,在執行的時候,將會生成結果序列。html

LINQ to Object和LINQ to SQL有何區別?

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語句並不保證必定能夠成功。編程

延遲執行 (Lazy Loading)

大部分LINQ語句是在最終結果的第一個元素被訪問的時候(即在foreach中調用MoveNext方法)才真正開始運算的,這個特色稱爲延遲執行。通常來講,返回另一個序列(一般爲IEnumerable<T>或IQueryable<T>)的操做,使用延遲執行,而返回單一值的運算,使用當即執行。數組

Select方法不會觸發LINQ的執行。一些觸發的方式是:編程語言

  • foreach循環
  • ToList,ToArray,ToDictionary方法等

 

 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 這麼靈活。

相關文章
相關標籤/搜索