LINQ体系结构概述

开发 后端
这里介绍LINQ体系结构,LINQ 是支持以类型安全方式查询数据的一系列语言扩展;它将在代号为“Orcas”的下一个版本 Visual Studio 中发布。

Linq有很多值得学习的地方,这里我们主要介绍LINQ体系结构,包括介绍Where 运算符的实现等方面。

简单地说,LINQ 是支持以类型安全方式查询数据的一系列语言扩展;它将在代号为“Orcas”的下一个版本 Visual Studio 中发布。待查询数据的形式可以是 XML(LINQ 到 XML)、数据库(启用 LINQ 的 ADO.NET,其中包括 LINQ 到 SQL、LINQ 到 Dataset 和 LINQ 到 Entities)和对象 (LINQ 到 Objects) 等。LINQ体系结构如下图所示。

LINQ体系结构

LINQ体系结构

让我们看一些代码。在即将发布的“Orcas”版 C# 中,LINQ 查询可能如下所示:

  1. var overdrawnQuery = from account in db.Accounts where account.
    Balance 
    < 0select new { account.Name, account.Address }; 

当使用 foreach 遍历此查询的结果时,返回的每个元素都将包含一个余额小于 0 的帐户的名称和地址。
从以上示例中立即可以看出该语法类似于 SQL。几年前,Anders Hejlsberg(C# 的***设计师)和 Peter Golde 曾考虑扩展 C# 以更好地集成数据查询。Peter 时任 C# 编译器开发主管,当时正在研究扩展 C# 编译器的可能性,特别是支持可验证 SQL 之类特定于域的语言语法的加载项。另一方面,Anders 则在设想更深入、更特定级别的集成。他当时正在构思一组“序列运算符”,能在实现 IEnumerable 的任何集合以及实现 IQueryable 的远程类型查询上运行。最终,序列运算符的构思获得了大多数支持,并且 Anders 于 2004 年初向比尔·盖茨的 Thinkweek 递交了一份关于本构思的文件。反馈对此给予了充分肯定。在设计初期,简单查询的语法如下所示:

  1. sequence<Customer> locals = customers.where(ZipCode == 98112);  

在此例中,Sequence 是 IEnumerable<T> 的别名;“where”一词是编译器能理解的一种特殊运算符。Where 运算符的实现是一种接受 predicate 委托(即 bool Pred<T>(T item) 形式的委托)的普通 C# 静态方法。本构思的目的是让编辑器具备与运算符有关的特殊知识。这样将允许编译器正确调用静态方法并创建代码,将委托与表达式联系起来。假设上述示例是 C# 的理想查询语法。在没有任何语言扩展的情况下,该查询在 C# 2.0 中又会是什么样子?

  1. IEnumerable<Customer> locals = EnumerableExtensions.
  2. Where(customers,delegate(Customer c)  
  3. {  
  4. return c.ZipCode == 98112;  
  5. };  

这个代码惊人地冗长,而且更糟糕的是,需要非常仔细地研究才能找到相关的筛选器 (ZipCode == 98112)。这只是一个简单的例子;试想一下,如果使用数个筛选器、投影等,要读懂代码该有多难。冗长的根源在于匿名方法所要求的语法。在理想的查询中,除了要计算的表达式,表达式不会提出任何要求。随后,编译器将尝试推断上下文;例如,ZipCode 实际上引用了 Customer 上定义的 ZipCode。如何解决这一问题?将特定运算符的知识硬编码到语言中并不能令语言设计团队满意,因此他们开始为匿名方法寻求替代语法。他们要求该语法应极其简练,但又不必比匿名方法当前所需的编译器要求更多的知识。以上介绍LINQ体系结构。

【编辑推荐】

  1. LINQ匿名类型分析
  2. LINQ Where子句介绍
  3. LINQ使用Where扩展方法
  4. 介绍LINQ一些强大功能
  5. Linq使用Select浅谈
责任编辑:佚名 来源: 赛迪网
相关推荐

2009-09-08 14:34:42

Linq to SQL

2010-06-22 13:56:24

Meego开发

2018-04-23 09:25:24

MySQL结构存储

2010-11-26 14:33:29

Microsoft O

2010-12-20 15:25:35

SharePoint Project Ser

2009-06-26 15:58:28

EJB

2012-02-06 17:22:44

MySQL

2009-07-15 13:46:26

Swing体系结构

2014-07-23 09:33:52

2010-08-16 12:54:21

ASON路由技术

2010-09-25 13:38:23

Inside JVM

2016-12-26 10:29:01

Spring框架结构

2010-06-21 14:51:14

ASON路由

2010-04-23 09:13:05

Oracle体系结构

2009-07-10 16:07:10

TikeSwing创建MVC体系结构

2013-08-01 11:17:20

SAP

2009-07-09 13:52:41

Inside JVM

2013-09-02 15:53:16

Windows

2010-09-16 15:22:30

JVM体系结构

2023-07-04 15:00:47

微服务架构开发
点赞
收藏

51CTO技术栈公众号