欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

LINQ教程之LINQ操作語法

 更新時間:2022年03月07日 11:45:19   作者:.NET開發(fā)菜鳥  
本文詳細講解了LINQ的操作語法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

LINQ查詢時有兩種語法可供選擇:查詢表達式語法(Query Expression)和方法語法(Fluent Syntax)。

一、查詢表達式語法

查詢表達式語法是一種更接近SQL語法的查詢方式。

LINQ查詢表達式語法如下:

from<range variable> in <IEnumerable<T> or IQueryable<T> Collection>
<Standard Query  Operators> <lambda expression>
<select or groupBy operator> <result   formation>

LINQ查詢表達式

約束LINQ查詢表達式必須以from子句開頭,以select或group子句介紹
關(guān)鍵字功能
from....in...

指定要查詢的數(shù)據(jù)源以及范圍變量,多個from子句則表示從多個數(shù)據(jù)源查找數(shù)據(jù)。注意:C#編譯器會把“復(fù)合from子句”的查詢表達式轉(zhuǎn)換為SelectMany()擴展方法。

join…in…on…equals…指定多個數(shù)據(jù)源的關(guān)聯(lián)方式
let引入用于存儲查詢表達式中子表達式結(jié)果的范圍變量。通常能達到層次感會更好,使代碼更易于閱讀。
orderby、descending指定元素的排序字段和排序方式。當有多個排序字段時,由字段順序確定主次關(guān)系,可指定升序和降序兩種排序方式
where指定元素的篩選條件。多個where子句則表示了并列條件,必須全部都滿足才能入選。每個where子句可以使用謂詞&&、||連接多個條件表達式。
group指定元素的分組字段。
select指定查詢要返回的目標數(shù)據(jù),可以指定任何類型,甚至是匿名類型。(目前通常被指定為匿名類型)
into 

提供一個臨時的標識符。該標識可以引用join、group和select子句的結(jié)果。

1)        直接出現(xiàn)在join子句之后的into關(guān)鍵字會被翻譯為GroupJoin。(into之前的查詢變量可以繼續(xù)使用)

2)        select或group子句之后的into它會重新開始一個查詢,讓我們可以繼續(xù)引入where, orderby和select子句,它是對分步構(gòu)建查詢表達式的一種簡寫方式。(into之前的查詢變量都不可再使用)

查詢語法從一個From子句開始,然后是一個Range變量。 From子句的結(jié)構(gòu)類似于“From rangeVariableName in IEnumerablecollection”。 在英語中,這意味著,從集合中的每個對象。 它類似于foreach循環(huán):foreach(student in studentList)。

在From子句之后,您可以使用不同的標準查詢運算符來過濾,分組,連接集合的元素。 LINQ中有大約50個標準查詢運算符。標準查詢運算符后面通常跟一個條件,這個條件通常使用lambda表達式來表示。

LINQ查詢語法總是以Select或Group子句結(jié)束。 Select子句用于對數(shù)據(jù)進行整形。 您可以選擇整個對象,因為它是或只有它的一些屬性。 在上面的例子中,我們選擇了每個結(jié)果字符串元素。

例如:我們要從數(shù)組中查詢出偶數(shù),查詢表達式示例代碼如下:

var result = from p in ints where p % 2 == 0 select p;

查詢表達式語法要點總結(jié):

1、查詢表達式語法與SQL(結(jié)構(gòu)查詢語言)語法相同。

2、查詢語法必須以from子句開頭,可以以Select或GroupBy子句結(jié)束 。

3、使用各種其他操作,如過濾,連接,分組,排序運算符以構(gòu)造所需的結(jié)果。

4、隱式類型變量 - var可以用于保存LINQ查詢的結(jié)果。

二、方法語法

方法語法(也稱為流利語法)主要利用System.Linq.Enumerable類中定義的擴展方法和Lambda表達式方式進行查詢,類似于如何調(diào)用任何類的擴展方法。

以下是一個示例LINQ方法語法的查詢,返回數(shù)組中的偶數(shù):

var result = ints.Where(p => p % 2 == 0).ToArray();

從上面的示例代碼中可以看出:方法語法包括擴展方法和Lambda表達式。 擴展方法Where()在Enumerable類中定義。

如果你檢查Where擴展方法的簽名,你會發(fā)現(xiàn)Where方法接受一個謂詞委托,如Func <Student,bool>。 這意味著您可以傳遞任何接受Student對象作為輸入?yún)?shù)的委托函數(shù),并返回一個布爾值,如下圖所示。 lambda表達式作為在Where子句中傳遞的委托傳遞。 在下一節(jié)中學習lambda表達式。

三、查詢表達式語法VS方法語法

查詢表達式語法與方法語法存在著緊密的關(guān)系
1、CLR本身并不理解查詢表達式語法,它只理解方法語法。
2、編譯器負責在編譯時將查詢表達式語法翻譯為方法語法。
3、大部分方法語法都有對應(yīng)的查詢表達式語法形式:如Select()對應(yīng)select、OrderBy()對應(yīng)orderby
4、部分查詢方法目前在C#中還沒有對應(yīng)的查詢語句:如Count()和Max(),這是只能采用以下替代方案:
  方法語法
  查詢表達式語法+方法語法的混合方式

到此這篇關(guān)于LINQ操作語法的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論