LINQ使用Where扩展方法

开发 后端
这里介绍使用LINQ Where扩展方法,把一个查询语句写成多个扩展函数的方式,这其实是编译器处理查询语句的方法。

LINQ有很多值得学习的地方,这里我们主要介绍使用LINQ Where扩展方法,包括介绍书写带Where子句的LINQ等方面。

我们除了可以如下方式书写带Where子句的LINQ外:

  1. from p in products where p.UnitsInStock > 0 && p.UnitPrice > 3.00M select p; 

还可以对数组(所有实现了IEnumerable接口的对象都可以)的使用LINQ here扩展方法。

把一个查询语句写成多个扩展函数的方式,这其实是编译器处理查询语句的方法,比如下面的查询语句:

  1. int[] arr = new int[] { 8, 5, 89, 3, 56, 4, 1, 58 };  
  2. var m = from n in arr where n < 5 orderby n select n;  

编译器在编译后,替我们产生的代码等价于如下的代码:

  1. IOrderedSequence m = arr.Where(delegate (int n) {  
  2. return (n < 5);  
  3. }).OrderBy(delegate (int n) {  
  4. return n;  
  5. });  

下面我们来看一个使用LINQ here扩展方法的例子:

我们有一个字符串数组,一次是0到9的英文单词,我们查询出这10个字符的长度比它所在数组的位置 这两个数字比较小的英文单词.

这个查询可能有些绕口,你可以先看下面这些代码:

  1. public static void LinqDemo01()  
  2. {  
  3. string[] digits = { "zero", "one", "two", "three", "four", 
    "five", "six", "seven", "eight", "nine" };  
  4. var shortDigits = digits.Where((dd, aa) => dd.Length < aa);  
  5. Console.WriteLine("Short digits:");  
  6. foreach (var d in shortDigits)  
  7. Console.WriteLine("The word {0} is shorter than its value.", d);  
  8. }  

输出结果:

  1. Short digits:  
  2. The word five is shorter than its value.  
  3. The word six is shorter than its value.  
  4. The word seven is shorter than its value.  
  5. The word eight is shorter than its value.  
  6. The word nine is shorter than its value.  

【编辑推荐】

  1. LINQ to SQL Table浅谈
  2. Linq语句问题的解决方法
  3. Ling to sql更新实体概述
  4. Linq实体继承简单描述
  5. Linq Library概述
责任编辑:佚名 来源: IT168
相关推荐

2009-09-11 10:20:36

Linq扩展方法

2009-09-17 11:29:50

Linq扩展方法

2009-09-08 15:19:52

Linq Where操

2009-09-18 16:07:10

Linq Where操

2009-09-10 17:30:15

LINQ Where子

2009-09-14 09:49:08

Linq扩展函数

2009-09-08 15:39:13

Linq使用Inser

2009-09-17 14:21:19

LINQ表达式

2009-09-14 16:41:23

LINQ To XML

2009-09-09 13:18:26

Linq Submit

2009-09-09 09:59:08

Linq调用LoadP

2009-09-10 14:54:15

LINQ使用Skip操

2009-09-08 16:08:44

Linq使用order

2009-09-15 16:44:44

Linq排序

2009-05-11 10:40:36

.NETLINQforeach

2009-09-09 16:21:31

Linq使用sqlme

2009-09-10 15:45:07

Linq使用Selec

2009-09-09 16:01:21

Linq实体继承使用

2009-09-08 09:24:50

LINQ查询

2009-08-27 18:04:01

c#扩展方法string
点赞
收藏

51CTO技术栈公众号