LINQ数据源详细描述

开发 后端
这里介绍LINQ源数据还没有作为可查询类型出现在内存中,则 LINQ 提供程序必须以此方式表示源数据。

LINQ有很多值得学习的地方,这里我们主要介绍LINQ数据源,包括介绍LINQ查询表达式等方面。

LINQ数据源

在上一个示例中,由于数据源是数组,因此它隐式支持泛型 IEnumerable<(Of <(T>)>) 接口。这一事实意味着该数据源可以用 LINQ 进行查询。在 foreach 语句中执行查询,而 foreach 要求使用 IEnumerable 或 IEnumerable<(Of <(T>)>)。支持 IEnumerable<(Of <(T>)>) 或派生接口(如泛型 IQueryable<(Of <(T>)>))的类型称为“可查询类型”。

可查询类型不需要进行修改或特殊处理就可以用作 LINQ数据源。如果LINQ源数据还没有作为可查询类型出现在内存中,则 LINQ 提供程序必须以此方式表示源数据。例如,LINQ to XML 将 XML 文档加载到可查询的 XElement 类型中:

  1. // Create a data source from an XML document.  
  2. // using System.Xml.Linq;  
  3. XElement contacts = XElement.Load(@"c:\myContactList.xml"); 

在 LINQ to SQL 中,首先手动或使用 对象关系设计器(O/R 设计器) 在设计时创建对象关系映射。针对这些对象编写查询,然后由 LINQ to SQL 在运行时处理与数据库的通信。在下面的示例中,Customer 表示数据库中的特定表,并且 Table 支持派生自 IEnumerable<(Of <(T>)>) 的泛型 IQueryable<(Of <(T>)>) 接口。

  1. DataContext db = new DataContext(@"c:\northwind\northwnd.mdf"); 

有关如何创建特定类型的数据源的更多信息,请参见各种 LINQ 提供程序的文档。但基本规则非常简单:LINQ数据源是支持泛型 IEnumerable<(Of <(T>)>) 接口或从该接口继承的接口的任意对象。

LINQ查询

查询指定要从数据源中检索的信息。查询还可以指定在返回这些信息之前如何对其进行排序、分组和结构化。查询存储在查询变量中,并用查询表达式进行初始化。为使编写查询的工作变得更加容易,C# 引入了新的查询语法。

上一个示例中的查询从整数数组中返回所有偶数。该查询表达式包含三个子句:from、where 和 select。(如果您熟悉 SQL,您会注意到这些子句的顺序与 SQL 中的顺序相反。) from 子句指定数据源,where 子句应用筛选器,select 子句指定返回的元素的类型。LINQ查询表达式(C# 编程指南)一节中详细讨论了这些子句和其他查询子句。目前需要注意的是,在 LINQ 中,查询变量本身不执行任何操作并且不返回任何数据。它只是存储在以后某个时刻执行查询时为生成结果而必需的信息。有关在幕后是如何构建查询的更多信息,请参见标准查询运算符概述。

【编辑推荐】

  1. LinqDataSource控件剖析
  2. Linq To Sql学习经验
  3. Linq String类型浅析
  4. Linq组合查询之集成数据库语言查询
  5. Linq To SQL输出SQL语句剖析
责任编辑:佚名 来源: 博客园
相关推荐

2009-09-14 14:58:52

LINQ to XML

2009-09-14 13:14:49

LINQ序列

2009-09-14 16:33:55

LINQ To XML

2009-09-24 16:19:53

Hibernate应用

2009-09-25 14:28:40

Hibernate S

2009-09-15 17:15:33

Linq排序

2010-02-05 16:58:18

Android服务

2009-11-18 11:14:49

2009-11-05 13:17:32

Visual Stud

2009-08-10 16:40:03

C#索引器

2009-09-25 11:04:32

Hibernate3实

2010-04-09 17:45:06

Oracle索引

2009-10-15 14:59:45

网络布线光纤技术

2009-10-10 10:04:50

RHEL合法使用

2009-08-27 15:17:40

C# const变量

2009-09-07 15:15:43

2009-08-26 15:53:48

C#扩展方法

2010-07-22 10:30:36

SQL Server数

2010-09-08 15:10:48

2009-09-03 17:59:18

C#调用事件
点赞
收藏

51CTO技术栈公众号