偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

LINQ Where子句介紹

開發(fā) 后端
這里介紹LINQ Where子句,LINQ中所有關(guān)鍵字比如 Select,SelectMany, Count, All 等等其實(shí)都是用擴(kuò)展方法來(lái)實(shí)現(xiàn)的。

在向大家詳細(xì)介紹LINQ Where子句之前,首先讓大家了解下LINQ Where子句其實(shí)是用擴(kuò)展方法來(lái)實(shí)現(xiàn)的,然后全面介紹LINQ Where子句。

LINQ Where子句其實(shí)是用擴(kuò)展方法來(lái)實(shí)現(xiàn)的

微軟替我們實(shí)現(xiàn)的 LINQ Where子句對(duì)應(yīng)的擴(kuò)展函數(shù)實(shí)際是如下的定義:

  1. namespace System.Linq  
  2. {  
  3. public delegate TResult Func(TArg0 arg0, TArg1 arg1);  
  4. public static class Enumerable  
  5. {  
  6. public static IEnumerable Where(this IEnumerable source, Func predicate);  
  7. public static IEnumerable Where(this IEnumerable source, Func predicate);  
  8. }  

我們這個(gè)擴(kuò)展函數(shù)參數(shù):Func predicate 的定義看上面代碼的綠色delegate 代碼。

LINQ Where子句參數(shù)書寫的是Lambda 表達(dá)式

  1. (dd, aa) => dd.Length < aa 就相當(dāng)于 C# 2.0 的匿名函數(shù)。 

LINQ中所有關(guān)鍵字比如 Select,SelectMany, Count, All 等等其實(shí)都是用擴(kuò)展方法來(lái)實(shí)現(xiàn)的。上面的用法同樣也適用于這些關(guān)鍵字子句。這個(gè)LINQ Where子句中Lambda 表達(dá)式第二個(gè)參數(shù)是數(shù)組索引,我們可以在Lambda 表達(dá)式內(nèi)部使用數(shù)組索引。來(lái)做一些復(fù)雜的判斷。具有數(shù)組索引的LINQ關(guān)鍵字除了Where還以下幾個(gè)Select,SelectMany, Count, All。

Select子句使用數(shù)組索引的例子

下面代碼有一個(gè)整數(shù)數(shù)組,我們找出這個(gè)數(shù)字是否跟他在這個(gè)數(shù)組的位置一樣

  1. public static void LinqDemo01()  
  2. {  
  3. int[] numbers = { 5, 4, 1, 3, 9, 8, 6, 7, 2, 0 };  
  4. var numsInPlace = numbers.Select((num, index) => 
    new { 
    Num = numInPlace = (num == index) });  
  5. Console.WriteLine("Number: In-place?");  
  6. foreach (var n in numsInPlace)  
  7. Console.WriteLine("{0}: {1}", n.Num, n.InPlace);  

SelectMany 子句使用數(shù)組索引的例子

幾個(gè)句子組成的數(shù)組,我們希望把這幾個(gè)句子拆分成單詞,并顯示每個(gè)單詞在那個(gè)句子中。查詢語(yǔ)句如下:

  1. public static void Demo01()  
  2. {  
  3. string[] text = { "Albert was here",  
  4. "Burke slept late",  
  5. "Connor is happy" };  
  6. var tt = text.SelectMany((s, index) => from ss in s.Split(' ') 
    select new { 
    Word = ssIndex = index });  
  7. foreach (var n in tt)  
  8. Console.WriteLine("{0}:{1}", n.Word,n.Index);  
  9. }  

【編輯推薦】

  1. LINQ to SQL Table淺談
  2. Linq語(yǔ)句問題的解決方法
  3. Ling to sql更新實(shí)體概述
  4. Linq實(shí)體繼承簡(jiǎn)單描述
  5. Linq Library概述
責(zé)任編輯:佚名 來(lái)源: IT168
相關(guān)推薦

2010-09-26 14:46:19

SQL WHERE子句

2009-09-16 11:19:48

Linq Select

2009-09-16 13:02:12

LINQ查詢子句

2010-09-26 09:50:36

SQL Where子句

2009-11-19 14:59:25

Oracle Wher

2009-09-18 16:07:10

Linq Where操

2009-09-08 15:19:52

Linq Where操

2009-09-10 16:32:19

LINQ Where

2009-08-27 13:10:54

LINQ from子句

2011-06-08 15:08:38

MySQLWhere優(yōu)化

2009-09-08 10:50:20

2009-09-08 13:07:15

介紹Linq to S

2009-09-16 10:38:43

LINQ查詢

2009-09-11 09:41:19

LINQ to SQL

2009-08-13 11:01:32

LINQPadLINQ工具

2009-09-09 14:20:49

LINQ To Luc

2009-09-18 09:25:06

LINQ Framew

2009-06-12 09:44:04

LINQ查詢復(fù)合from子句

2013-08-27 10:20:35

JavaLINQLinq4j

2009-09-07 17:05:10

LINQ進(jìn)行查詢
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)