LINQ Where子句介绍

开发 后端
这里介绍LINQ Where子句,LINQ中所有关键字比如 Select,SelectMany, Count, All 等等其实都是用扩展方法来实现的。

在向大家详细介绍LINQ Where子句之前,首先让大家了解下LINQ Where子句其实是用扩展方法来实现的,然后全面介绍LINQ Where子句。

LINQ Where子句其实是用扩展方法来实现的

微软替我们实现的 LINQ Where子句对应的扩展函数实际是如下的定义:

  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. }  

我们这个扩展函数参数:Func predicate 的定义看上面代码的绿色delegate 代码。

LINQ Where子句参数书写的是Lambda 表达式

  1. (dd, aa) => dd.Length < aa 就相当于 C# 2.0 的匿名函数。 

LINQ中所有关键字比如 Select,SelectMany, Count, All 等等其实都是用扩展方法来实现的。上面的用法同样也适用于这些关键字子句。这个LINQ Where子句中Lambda 表达式第二个参数是数组索引,我们可以在Lambda 表达式内部使用数组索引。来做一些复杂的判断。具有数组索引的LINQ关键字除了Where还以下几个Select,SelectMany, Count, All。

Select子句使用数组索引的例子

下面代码有一个整数数组,我们找出这个数字是否跟他在这个数组的位置一样

  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 子句使用数组索引的例子

几个句子组成的数组,我们希望把这几个句子拆分成单词,并显示每个单词在那个句子中。查询语句如下:

  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概述
责任编辑:佚名 来源: IT168
相关推荐

2010-09-26 14:46:19

SQL WHERE子句

2009-09-16 13:02:12

LINQ查询子句

2009-11-19 14:59:25

Oracle Wher

2009-09-16 11:19:48

Linq Select

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

2011-06-08 15:08:38

MySQLWhere优化

2009-08-27 13:10:54

LINQ from子句

2009-09-11 09:41:19

LINQ to SQL

2009-09-16 10:38:43

LINQ查询

2009-09-08 10:50:20

2009-09-08 13:07:15

介绍Linq to S

2009-08-13 11:01:32

LINQPadLINQ工具

2009-06-12 09:44:04

LINQ查询复合from子句

2009-09-09 14:20:49

LINQ To Luc

2009-09-18 09:25:06

LINQ Framew

2013-08-27 10:20:35

JavaLINQLinq4j

2009-09-07 17:05:10

LINQ进行查询
点赞
收藏

51CTO技术栈公众号