




版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
1、Lambda表達式詳細總結(jié)(一)輸入?yún)?shù)在Lambda表達式中,輸入?yún)?shù)是Lambda運算符的左邊部分。它包含參數(shù)的數(shù)量可以為0、1或者多個。只有當輸入?yún)?shù)為1時,Lambda表達式左邊的一對小括弧才可以省略。輸入?yún)?shù)的數(shù)量大于或者等于2時,Lambda表達式左邊的一對小括弧中的多個參數(shù)質(zhì)檢使用逗號(,)分割。示例1下面創(chuàng)建一個Lambda表達式,它的輸入?yún)?shù)的數(shù)量為0.該表達式將顯示“This is a Lambda expression”字符串。csharp view plain copy 1. ()=>Console.WriteLine("T
2、his is a Lambda expression."); 分析2由于上述Lambda表達式的輸入?yún)?shù)的數(shù)量為0,因此,該Lambda表達式的左邊部分的一對小括弧不能被省略。示例2下面創(chuàng)建一個Lambda表達式,它的輸入?yún)?shù)包含一個參數(shù):m。該表達式將計算m參數(shù)與2的乘積。csharp view plain copy 1. m=>m*2; 分析2上述Lambda表達式的輸入?yún)?shù)省略了一對小括弧,它與“(m)=>m*2”Lambda表達式是等效的。示例3下面創(chuàng)
3、建一個Lambda表達式,它的輸入?yún)?shù)包含兩個參數(shù):m和n。該表達式將計算m和n參數(shù)的乘積。csharp view plain copy 1. (m,n)=>m*n; (二)表達式或語句塊多個Lambda表達式可以構(gòu)成Lambda語句塊。語句塊可以放到運算符的右邊,作為Lambda的主體。根據(jù)主題不同,Lambda表達式可以分為表達式Lambda和語句Lambda。語句塊中可以包含多條語句,并且可以包含循環(huán)、方法調(diào)用和if語句等。示例1下面創(chuàng)建一個Lambda表達式,它的右邊部分是一個表達式。該表達式計算m參數(shù)的平方值。csharp
4、160;view plain copy 1. m=>m*n; 分析1如果Lambda表達式的右邊部分是一個語句塊,那么該語句塊必須被""和""包圍。示例2下面創(chuàng)建一個Lambda表達式,它的輸入?yún)?shù)包括兩個參數(shù):m和n。該表達式的右邊包含2個表達式;第一個表達式計算m和n參數(shù)的乘積,結(jié)果保存為result變量;第二個表達式顯示result變量的值。csharp view plain copy 1. (m,n)=>int result=m*n; Cons
5、ole.WriteLine(result); 分析2上述Lambda表達式的右邊部分包含2個表達式,因此,該表達式的右邊部分必須被""和""包圍。(三)查詢表達式查詢表達式是一種使用查詢語法表示的表達式,它用于查詢和轉(zhuǎn)換來自任意支持LINQ的數(shù)據(jù)源中的數(shù)據(jù)。查詢表達式使用許多常見的C#語言構(gòu)造,易讀簡潔,容易掌握。它由一組類似于SQL或XQuery的聲明性語法編寫的子句組成。每一個子句可以包含一個或多個C#表達式。這些C#表達式本身也可能是查詢表達式或包含查詢表達式。查詢表達式必須以from子句開頭,以select或group子句結(jié)
6、束。第一個from子句和最后一個select子句或group子句之間,可以包含一個活多個where子句、let子句、join子 句、orderby子句和group子句,甚至還可以是from子句。它包括8個基本子句,具體說明如下所示。from子句:指定查詢操作的數(shù)據(jù)源和范圍變量。select子句:指定查詢結(jié)果的類型和表現(xiàn)形式。where子句:指定篩選元素的邏輯條件。let子句:引入用來臨時保存查詢表達式中的字表達式結(jié)果的范圍變量。orderby子句:對查詢結(jié)果進行排序操作,包括升序和降序。group子句:對查詢結(jié)果進行分組。into子句:提供一個臨時標識符。join子句、group
7、子句或select子句可以通過該標識符引用查詢操作中的中堅結(jié)果。join子句:連接多個用于查詢操作的數(shù)據(jù)源。示例1下面創(chuàng)建一個查詢表達式query,該查詢表達式查詢arr數(shù)組中的每一個元素。intarr =new int0,1,2,3,4,5,6,7,8,9;分析1csharp view plain copy 1. var query1=from n in arr 2. &
8、#160; select n; 示例2下面創(chuàng)建一個查詢表達式query2.該查詢表達式查詢arr數(shù)組中大于6的元素。csharp view plain copy 1. int arr =new int0,1,2,3,4,5,6,7,8,9; 2. var query2=from n in arr 3. &
9、#160; where n >6 4. select n; 分析2變量只是保存查詢操作,而不是查詢的結(jié)果。當查詢表達式執(zhí)行查詢操作時,才會計算該查詢表達式的結(jié)果。以上兩個變量的類型都屬于集合類型。(四)from子句from子句用來指定查詢表達式的數(shù)據(jù)源和范圍變量。它是查
10、詢表達式的必有部分,并且它出現(xiàn)在最開始。數(shù)據(jù)源不但可以包括查詢本身的數(shù)據(jù)源,而且還可以包括子查詢的數(shù)據(jù)源。范圍變量用來表示數(shù)據(jù)源序列中的每一個元素。注意:from子句指定的數(shù)據(jù)源的類型必須為IEnumerable,IEnumerable<T>或一種派生類型。示例1下面創(chuàng)建一個查詢表達式query。該查詢表達式查詢arr數(shù)組中的每一個元素。在query查詢表達式中,arr數(shù)組為數(shù)據(jù)源,n為范圍變量。n范圍變量的類型arr數(shù)據(jù)源的元素類型。分析1csharp view plain copy 1. int arr =new in
11、t 0,1,2,3,4,5,67,8,9; 2. var query =from n in arr 3. select n; 下面我們來學習數(shù)據(jù)源和包含不同的from子句查詢表達式。數(shù)據(jù)源:指定數(shù)據(jù)的來源,它的形式可以為靜態(tài)數(shù)組、動態(tài)數(shù)組(Arraylist)、集合、數(shù)據(jù)集(DataSet)、數(shù)據(jù)表、MML片段、MML文件等。如果數(shù)據(jù)源實現(xiàn)了IEnumerable<T>接口,那么編譯器可以推斷范圍變量的類型為其元素類型。例如:數(shù)據(jù)源的類
12、型為IEnumerable<UserInfo>,那么可以推斷出范圍 變量的類型為UseInfo。示例2下面創(chuàng)建一個查詢表達式query。該查詢表達式查詢list反省數(shù)組中的每一個元素。在query查詢表達式中,list反省數(shù)組為數(shù)據(jù)源。u為范圍變量。u范圍變量的類型為list數(shù)據(jù)源的元素類型(UserInfo)。分析2csharp view plain copy 1. List<UserInfo> list=. 2. var query =from u in
13、list 3. select u; 如果當數(shù)據(jù)源是非泛型IEnumerable類型(如ArrayList等)時,需要顯示指定范圍變量的類型。示例3下面創(chuàng)建一個查詢表達式query。該查詢表達式查詢list數(shù)組中的每一個元素。在query查詢表達式中,list數(shù)組為數(shù)據(jù)源,u為范圍變量。u范圍變量的類型被指定為list數(shù)據(jù)源的元素類型(UserInfo)。分析3csharp view plain
14、0;copy 1. ArrayList list =new ArrayList(); 2. list.Add(.); 3. . 4. var query =from UserInfo u in list 5. select u; 包含單個from子句的查詢表達式在查詢表達式中,from子句至少有一個。當from子句只有一個時,構(gòu)成
15、的查詢表達式被稱為包含單個from子句的查詢表達式。一般的,包含單個from子句的查詢表達式只包含一個數(shù)據(jù)源。示例4下面創(chuàng)建一個查詢表達式query。該查詢表達式查詢arr數(shù)組中的每一個元素,它就是一個包含單個from子句的查詢表達式。分析4csharp view plain copy 1. int arr =new int0,1,12,3,4,5,6,7,8,9; 2. var query =from n in arr 3. &
16、#160; select n; 包含多個from子句的查詢表達式在查詢表達式中,當from子句有兩個或兩個以上時,構(gòu)成的查詢表達式被稱為包含多個from子句的查詢表達式。示例5下面創(chuàng)建一個查詢表達式query。該查詢表達式包含兩個from子句,他們分別查詢兩個獨立的數(shù)據(jù)源;arr1數(shù)組和arr2數(shù)組。最后,使用select子句計算當前元素的和。分析5csharp view plain copy 1. int arr1= new int
17、0,1,2,3,4,5,6,7,8,9; 2. int arr2=new int 0,1,2,3,4,5,6,7,8,9; 3. var query =from a in arr1 4. from b in arr2 5. selec
18、t a +b; 包含符合from子句的查詢表達式在查詢表達式中,有可能查詢表達式的數(shù)據(jù)源中的每一個元素本身也作為該查詢表達式的數(shù)據(jù)源。那么要查詢數(shù)據(jù)源中的每一個元素中的元素,則需要使用符合from子句。符合from子句類似于嵌套的foreach語句。示例6下面創(chuàng)建一個名稱為Test的類,該類包含兩個字段:Name和AliasName。其中,Name字段的類型為string,AliasName字段的類型為string類型列表。因此,它也可以作為子查詢表達式的數(shù)據(jù)源。分析6csharp view plain copy 1. p
19、ublic class Test 2. 3. Public string Name; 4. Public List<string> AliasName; 5. 示例7下面創(chuàng)建一個查詢表達式query。該查詢表達式包含了一個符合from子句:第一個from子句查詢list泛型集合;第二個from子句查詢list集合中元
20、素的AliasName字段,為第一個from子句的子查詢。最后,使用select子句將u變量的Name屬性的值和name變量的值拼接為一個字符串。分析7csharp view plain copy 1. List<MUserInfo> list =. 2. var query =from u in list 3. from name in u.Alia
21、sName 4. select u.Name+name; (五)select子句select子句用來指定將在執(zhí)行查詢時產(chǎn)生的值的類型。查詢表達式必須以select子句或group子句結(jié)束。示例1下面創(chuàng)建一個查詢表達式query。該查詢表達式查詢arr數(shù)組中的每一個元素。分析1csharp view plain copy 1. int arr =new int 0,1,2,3,4,5,6,7,8,9; 2. var query =f
22、rom n in arr 3. select n; 示例2下面創(chuàng)建一個查詢表達式query。該查詢表達式查詢arr數(shù)組中的每一個元素和10的乘積。csharp view plain copy 1. int arr =new int 0,1,2,3,4,5,6,7,8,9; 2. var query =from
23、;n in arr 3. select n*10; 分析2select子句中的“n*10”表達式?jīng)Q定了查詢結(jié)果的表現(xiàn)形式,即計算每一個元素和10的乘積。示例3下面創(chuàng)建一個查詢表達式query。該查詢表達式查詢arr數(shù)組中的每一個元素,查詢結(jié)果是一個對象的集合對象包含兩個屬性:ID和Name,它在select子句中由匿名對象初始化器創(chuàng)建。每一個對象的ID屬性的值是當前元素的值、Name屬性的值為元素的值的字符串的表現(xiàn)形式。分析3csharp view p
24、lain copy 1. int arr =new int0,1,2,3,4,5,6,7,8,9; 2. var query =from n in arr 3. select new 4. 5.
25、 ID=n, 6. Name =n.ToString() 7. (六)where子句where子句用來指導將在查詢表達式中返回數(shù)據(jù)源中的哪些元素。它將一個布爾條件應用于數(shù)據(jù)源中的每個元素,并返回指定條件的元素。查詢表達式可以包含一個或多個where子句。示例1下面創(chuàng)建一個查詢表達式query。該查詢表達式從arr數(shù)組中查詢小于3的元素csharp
26、0;view plain copy 1. int arr =new int 0,1,2,3,4,5,6,7,8,9; 2. var query =from n in arr 3. where n <3 4.
27、;select n; 分析1上述where子句只包含一個布爾表達式“n<3”,該表達式將篩選小于3的元素。在一個where子句中,也可以包含多個布爾表達式,各個表達式直接使用邏輯運算符(如&&和|)分隔。示例2下面創(chuàng)建一個查詢表達式query。該查詢表達式從arr數(shù)組中查詢大于3且小于6的元素。csharp view plain copy 1. int arr =new int0,1,2,3,4,5,6,7,8,9; 2. var query
28、0;=from n in arr 3. where n >3 && n<6 4. select n;
29、 分析2上述where子句包含兩個布爾表達式"n>3"和"n<6",它們共同指定將篩選大于3且小于6的元素。這兩個布爾表達式使用&&運算符鏈接,即計算這兩個布爾表達式的邏輯與。where子句不但可以包含布爾表達式,而且還可以包含返回布爾值的方法。示例3下面創(chuàng)建一個查詢表達式query.該查詢表達式從arr數(shù)組中查詢?yōu)榕紨?shù)的元素。csharp view plain copy 1. int arr =new int0,1,2,3,4,5,6,7,8,9;
30、0; 2. private bool IsEven(int i) 3. 4. return i%2=0?true:false; 5. 6. var query =from n in arr 7.
31、; wehre IsEven(n) 8. select n; 分析3上述where子句包含一個返回布爾值的方法"IsEven(int i)"。該方法判定元素是否為偶數(shù)。如果是,則返回true,否則返回false。(七)let子句let子句用來創(chuàng)建一個新的范圍變量,它用于存儲子表達式的結(jié)果。let子句使用編程者提供的表達式的結(jié)
32、果初始化該變量。一旦初始化了該范圍變量的值,它就不能用于存儲其他的值。示例1下面創(chuàng)建一個查詢表達式query。該查詢表達式從arr數(shù)組中查詢?yōu)榕紨?shù)的元素。csharp view plain copy 1. int arr =new int0,1,2,3,4,5,6,7,8,9; 2. var query =from n in arr 3. let&
33、#160;isEven =return n%2=0?true:false; 4. where isEven 5. select n; 分析1"return n%2=0?true:false"表達式判斷n元素是否為偶數(shù)。如果是,則返回true,否則返回false?!發(fā)et
34、 isEven =return n%2=0?true:false”表達式使用let子句創(chuàng)建新的范圍變量isEven,用來保存"return n%2=0?true:false"表達式的結(jié)果。"where isEven"表達式使用where子句篩選isEven的值為true的元素。(八)orderby子句orderby子句可使返回的查詢結(jié)果按升序或者降序排序。升序由關鍵字ascending指定,而降序由關鍵字descending指定。注意:orderby子句默認排序方式為升序。示例1下面創(chuàng)建一個查詢表達式query。該查詢表達式從arr數(shù)組中查詢大于1且小于
35、6的元素,并且按照n元素對查詢結(jié)果進行降序排序。csharp view plain copy 1. int arr =new int0,1,2,3,4,5,6,7,8,9; 2. var query =from n in arr 3. where n>1 && n<6
36、4. orderby n descending 5. select n 分析1orderby子句可以包含一個或多個排序表達式,各個排序表達式使用逗號(,)分隔。示例2下面創(chuàng)建一個查詢表達式query。該查詢表達式從arr數(shù)組中查詢大于1且小于6的元素。它使用orderby子句對查詢結(jié)果進行排序,且包含兩個排序關鍵字,具體
37、說明如下所示:n%2:按照升序排序;n:按照降序排序。注意:n%2排序關鍵字優(yōu)先級大于n排序關鍵字。因此,該查詢表達式的結(jié)果首先按照n%2排序關鍵字升序排序,然后在按照n排序關鍵字降序排序。分析2在"orderby n%2 ascending,n descending"表達式中,第一個排序關鍵字后的"ascending"可以省略。因為默認排序方式為升序。(九)group子句group子句用來將查詢結(jié)果分組,并返回一對象序列。這些對象包含零個或更多個與改組的key值匹配的項,還可以使用group子句結(jié)束查詢表達式。注意:每一個分組都不是單個元素,而是一個序
38、列(也屬于集合)。示例1下面創(chuàng)建一個查詢表達式query。該查詢表達式從arr數(shù)組中查詢大于1且小于6的元素,并且按照n%2表達式的值對查詢結(jié)果進行分組。csharp view plain copy 1. int arr =new int0,1,2,3,4,5,6,7,8,9; 2. var query =from n in arr 3. wher
39、e n>1 && n<6 4. group n by n%2; 分析1query查詢表達式的結(jié)果是一個序列(類型為IEnumerable<IGrouping<int,int>>),該序列的元素類型為IGrouping<int,int>.其實,該查詢結(jié)果中的元素也是一個序列。示例2下面使用兩個foreach語句顯示query查詢表達式結(jié)
40、果中每一個元素的值。csharp view plain copy 1. foreach(var g in query) 2. 3. foreach(var o in g) 4. 5.
41、60; Console.WriteLine(0); 6. 7. 分析2使用group子句對查詢結(jié)果分組后,每一個分組都存在一個鍵(由key屬性表示)。通過key屬性可以獲取每一個分組的鍵的值。(十)into子句 into子句可以用來創(chuàng)建一個臨時標識符,將group、join或select子句的
42、結(jié)果存儲到這個標識符中。示例1下面創(chuàng)建一個查詢表達式query。該查詢表達式從arr數(shù)組中查詢大于1且小于6的元素,并且按照n%2表達式的值對查詢結(jié)果進行分組。該查詢表達式的具體說明如下所示:where n>1 && n<6:指定篩選大于1且小于6的元素。group n by n%2 into g: 按照n%2表達式的值對查詢結(jié)果進行分組,并使用into子句創(chuàng)建臨時標識符g。該臨時標識符臨時保存分組結(jié)果。from sn in g:從g標識符指定的每一個分組中查詢sn元素。select sn:表示查詢sn元素。csharp view plain c
43、opy 1. int arr =new int0,1,2,3,4,5,6,7,8,9; 2. var query =from n in arr 3. where n>1&& n<6 4. gr
44、oup n by n%2 into g 5. from sn in g 6. select sn; 分析1上述查詢表達式的查詢結(jié)果包括4個元素,依次為2、4、3和5(十一)join子句join子句用來連接兩個數(shù)據(jù)源,即設置兩個數(shù)據(jù)源之間的關系。join
45、子句支持以下3種常見聯(lián)接方式。內(nèi)部聯(lián)接:元素的鏈接關系 必須同時滿足兩個數(shù)據(jù)源,類似于SQL語句中的inner join子句。分組聯(lián)接:包含into子句的join子句。左外部聯(lián)接:元素的鏈接關系必須滿足聯(lián)接中的左數(shù)據(jù)源,類似于SQL語句中的left join子句。內(nèi)部聯(lián)接:join子句的內(nèi)部聯(lián)接要求兩個數(shù)據(jù)源都必須存在相同的值,即兩個數(shù)據(jù)源都必須存在滿足聯(lián)接關系的元素。示例1下面創(chuàng)建一個查詢表達式query。該查詢表達式使用join子句聯(lián)接了arra和arrb數(shù)組,具體說明如下。創(chuàng)建arra數(shù)組,它包含10個元素(09)。創(chuàng)建arrb數(shù)組,它包含5個元素(0、2、4、6和8)。創(chuàng)建query查
46、詢。from a in arra:從arra數(shù)組中選擇元素,并表示為a。where a <7: 從arra數(shù)組中選擇小于7的元素join b in arrb on a equals b: 將arra和arrb數(shù)組進行聯(lián)接,同時滿足a和b相等的條件。其中,b元素是arrb數(shù)組中的元素。select a: 選擇a元素。csharp view plain copy 1. int arra =new int 0,1,2,3,4,5,6,7,8,9; 2. int arrb =new int0,2,4,6,8; 3. var query =from a in arra 4. where a <7 5.
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 財務人員的責任與義務計劃
- 制定清晰的財務目標計劃
- 幼兒藝術表現(xiàn)的多樣性研究計劃
- 萬源市竹源煤業(yè)有限公司長石二煤礦礦山地質(zhì)環(huán)境保護與土地復墾方案情況
- 2025年經(jīng)典大班蒙氏數(shù)學標準教案
- 空乘禮儀知識培訓班課件
- 2025年四川貨運從業(yè)資格證考試模擬考試答案
- 胃癌治療手段
- 2025年洛陽貨運從業(yè)資格證考試技巧
- 3D打印技術知到課后答案智慧樹章節(jié)測試答案2025年春上海電子信息職業(yè)技術學院
- 辦公用品供貨服務計劃方案
- DB37∕T 5107-2018 城鎮(zhèn)排水管道檢測與評估技術規(guī)程
- 2022新冠疫苗疑似預防接種異常反應監(jiān)測和處置方案
- 酒精溶液體積濃度、質(zhì)量濃度與密度對照表
- 主要腸內(nèi)營養(yǎng)制劑成分比較
- 老年人各系統(tǒng)的老化改變
- 小學五年級綜合實踐課教案
- 煤礦井下供電常用計算公式及系數(shù)
- ISO14001:2015中文版(20211205141421)
- 汽車總裝車間板鏈輸送線的應用研究
- 工作日志模板
評論
0/150
提交評論