LINQ

LINQ

語言集成查詢
LINQ,語言集成查詢(LanguageIntegratedQuery)是一組用于c#和VisualBasic語言的擴展。它允許編寫C#或者VisualBasic代碼以查詢數據庫相同的方式操作内存數據。從技術角度而言,LINQ定義了大約40個查詢操作符,如select、from、in、where以及orderby(C#中)。
  • 中文名:語言集成查詢
  • 外文名:Language Integrated Query
  • 定義:
  • 開發公司:微軟
  • 語言:C#,Visual Basic

基本含義

借助于LINQ技術,我們可以使用一種類似SQL的語法來查詢任何形式的數據。從技術角度而言,LINQ定義了大約40個查詢操作符,如from,select,in,where,group by,orderby, … 使用這些操作符可以編寫查詢語句。不過,這些查詢還可以基于很多類型的數據,每個數據類型都需要一個單獨的LINQ類型。

經過了最近20年,面向對象編程技術(object-oriented(OO)programmingtechnologies)在工業領域的應用已經進入了一個穩定的發展階段。程序員現在都已經認同像類(classes)、對象(objects)、方法(methods)這樣的語言特性。

考察現在和下一代的技術,一個新的編程技術的重大挑戰開始呈現出來,即面向對象技術誕生以來并沒有解決降低訪問和整合信息數據(accessingandintegratinginformation)的複雜度的問題。其中兩個最主要訪問的數據源與數據庫(database)和XML(标準通用标記語言下的一個應用)相關。

LINQ提供了一條更常規的途徑即給.NetFramework添加一些可以應用于所有信息源(allsourcesofinformation)的具有多種用途(general-purpose)的語法查詢特性(queryfacilities),這是比向開發語言和運行時(runtime)添加一些關系數據(relational)特性或者類似XML特性(XML-specific)更好的方式。這些語法特性就叫做.NETLanguageIntegratedQuery(LINQ)。

包含DLinq和XLinq。

基礎知識

1.LINQ的讀法:(1)link(2)linq

2.LINQ的關鍵詞:from,select,in,where,groupby,orderby,…

3.LINQ的注意點:必須以select或者是groupby結束。

4.LINQ的寫法:

1)from臨時變量in實現IEnumerable接口的對象

where條件表達式

[orderby條件]

[groupby條件]

select臨時變量中被查詢的值

2)實現IEnumerable接口的對象.LINQ方法名(lambda表達式)。如:

stringinput="hellowworld";

intcount=input.Count(w=>w=='o');//查詢字母o出現的次數

能夠使用LINQ的對象需要實現IEnumerable接口。并且LINQ的查詢表達式是在一次創建對象時才被編譯的。

4.LINQ的全稱:Language-IntegratedQuery

5.命名空間:System.Linq;

注意:Linq是在.NETFramework3.5中出現的技術,所以在創建新項目的時候必須要選3.5或者更高版本,否則無法使用。

選擇3.5或更高版本的.NETFramework之後,創建的新項目中會自動包含System.Linq的命名空間。

原理淺析

LINQ(LanguageIntegratedQuery)是VisualStudio2008中的領軍人物。借助于LINQ技術,我們可以使用一種類似SQL的語法來查詢任何形式的數據。目前為止LINQ所支持的數據源有SQLServer、Oracle、XML(标準通用标記語言下的一個應用)以及内存中的數據集合。開發人員也可以使用其提供的擴展框架添加更多的數據源,例如MySQL、Amazon甚至是GoogleDesktop。

一般來講,這類查詢語句的一個重要特點就是可以并行化執行。雖然有些情況下并行可能會帶來一些問題,但這種情況非常少見。這樣也就水到渠成地引出了PLINQ這個并行處理的LINQ類庫。

PLINQ原名為ParallelLINQ,支持XML和内存中的數據集合。執行于遠程服務器上的查詢語句(例如LINQtoSQL)顯然無法實現這個功能。

将LINQ語句轉換為PLINQ語句極為簡單——隻需要在查詢語句中From子句所指定的數據源的最後添加.AsParallel()即可。随後Where、OrderBy和Select子句将自動改為調用這個并行的LINQ版本。

據MSDNMagazine介紹,PLINQ可以以三種方式執行。第一種是管道處理:一個線程用來讀取數據源,而其他的線程則用來處理查詢語句,二者同步進行——雖然這個單一的消費線程可能并不那麼容易與多個生産線程同步。不過若是能夠仔細配置好負載平衡的話,仍然會極大地減少内存占用。

第二種模式叫做“stopandgo”,用于處理結果集需要被一次返回時(例如調用ToList、ToArray或對結果排序)的情況。在這種模式下,将依次完成各個處理過程,并将結果統一返回給消費線程。這個模式在性能上将優于第一種模式,因為它省去了用來保持線程同步所花費的開銷。

最後一種方法叫做“invertedenumeration”。該方法并不需要實現收集到所有的輸出,然後在單一的線程中處理,而是将最終調用的函數通過ForAll擴展傳遞到每個線程中。這是目前為止最快的一種處理模式,不過這需要傳遞到ForAll中的函數是線程安全的,且最好不包含任何lock之類的互斥語句。

若是PLINQ中任意的一個線程抛出異常,那麼所有的其他線程将會被終止。若是抛出了多個異常,那麼這些異常将被組合成一個MultipleFailuresException類型的異常,但每個異常的調用堆棧仍會被保留。

使用優點

1、無需複雜學習過程即可上手

2、編寫更少代碼即可創建完整應用。

3、更快開發錯誤更少的應用程序。

4、無需求助奇怪的編程技巧就可合并數據源。

5、能夠大幅減少過程控制語句的代碼塊,使代碼的可讀性和可維護性大幅提高。

6、任何對象或數據源都可以定制實現Linq适配器,為數據交互帶來真正方便。

上一篇:ARC

下一篇:Hash

相關詞條

相關搜索

其它詞條