标准查询操作符概述及剖析

标准查询操作符简介

为了查看执行中的语言集成查询,我们将从一个简单的 C# 3.0 程序开始,该程序使用标准的查询操作符来处理数组的内容:

 
 
 
  1. using System;  
  2. using System.Query;  
  3. using System.Collections.Generic;  
  4.  
  5. class app {  
  6.   static void Main() {  
  7.     string[] names = { "Burke""Connor""Frank",   
  8.                        "Everett""Albert""George",   
  9.                        "Harris""David" };  
  10.  
  11.     IEnumerable expr = from s in names   
  12.                                where s.Length == 5  
  13.                                orderby s  
  14.                                select s.ToUpper();  
  15.  
  16.     foreach (string item in expr)  
  17.       Console.WriteLine(item);  
  18.   }  
  19. }  
  20.  

如果您编译并运行该程序,将看到以下输出:

 
 
 
  1. BURKE  
  2. DAVID  
  3. FRANK  

标准查询操作符工作原理

要了解语言集成查询如何工作,我们需要剖析该程序的第一个语句。

 
 
 
  1. IEnumerable expr = from s in names   
  2.                            where s.Length == 5  
  3.                            orderby s  
  4.                            select s.ToUpper();  

使用一个查询表达式 初始化局部变量 expr。通过应用一个或多个标准查询操作符或特定于域的操作符,查询表达式可以操作一个或多个信息源。该表达式使用了三个标准查询操作符:Where、OrderBy 和 Select。

Visual Basic 9.0 也支持 LINQ。以下是以 Visual Basic 9.0 编写的上述语句:

 
 
 
  1. Dim expr As IEnumerable(Of String) = _  
  2.                    Select s.ToUpper() _  
  3.                    From s in names _  
  4.                    Where s.Length = 5 _  
  5.                    Order By s  

这里显示的 C# 和 Visual Basic 语句均使用查询语法。与 foreach 语句一样,查询语法是一个方便的声明性代码缩写,您可以手动编写它。上述语句在语义上与以下所示的以 C# 编写的显式语法完全相同:

 
 
 
  1. IEnumerable expr = names   
  2.                            .Where(s => s.Length == 5)   
  3.                            .OrderBy(s => s)  
  4.                            .Select(s => s.ToUpper());  

Where、OrderBy 和 Select 操作符的参数称为 λ 表达式,它们是类似于委托的代码片段。它们允许将标准查询操作符单独定义为方法,并使用点标记串连在一起。这些方法共同构成了可扩展查询语言的基础。

【编辑推荐】

  1. .NET框架中的XML基础类:xsd.exe
  2. ASP.NET 2.0页面状态持续:ViewState与控件
  3. ASP.NET 2.0数据绑定控件的自定义集合
  4. 列表控件示例:HeadlineList
  5. ASP.NET 2.0数据绑定机制:生成控件
THE END