自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

LINQ Where子句介紹

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

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

LINQ Where子句其實是用擴展方法來實現(xiàn)的

微軟替我們實現(xiàn)的 LINQ Where子句對應(yīng)的擴展函數(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. }  

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

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

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

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

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

下面代碼有一個整數(shù)數(shù)組,我們找出這個數(shù)字是否跟他在這個數(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ù)組索引的例子

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

  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語句問題的解決方法
  3. Ling to sql更新實體概述
  4. Linq實體繼承簡單描述
  5. Linq Library概述
責(zé)任編輯:佚名 來源: IT168
相關(guān)推薦

2010-09-26 14:46:19

SQL WHERE子句

2009-09-16 13:02:12

LINQ查詢子句

2009-09-16 11:19:48

Linq Select

2009-11-19 14:59:25

Oracle Wher

2010-09-26 09:50:36

SQL Where子句

2009-09-08 15:19:52

Linq Where操

2009-09-18 16:07:10

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 13:07:15

介紹Linq to S

2009-09-08 10:50:20

2009-09-11 09:41:19

LINQ to SQL

2009-09-16 10:38:43

LINQ查詢

2009-08-13 11:01:32

LINQPadLINQ工具

2009-09-18 09:25:06

LINQ Framew

2009-09-09 14:20:49

LINQ To Luc

2009-06-12 09:44:04

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

2013-08-27 10:20:35

JavaLINQLinq4j

2009-09-09 09:36:25

Linq對象引用
點贊
收藏

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