LINQ 学习(二)

LINQ 进阶 总结

查询执行的时机:

查询分为以下三步:获取数据源、定义查询、执行查询;

定义查询后,查询直到需要枚举结果时才被真正执行,这种方式称为 延迟执行 (deferred execution)” ;当查询方法返回单一值时,查询立即执行;


LINQ 查询的两种方式:

1 Method Syntax, 查询方法方式:主要利用System.Linq.Enumerable 类中定义的扩展方法和 Lambda 表达式方式进行查询

2 Query Syntax, 查询语句方式:一种更接近 SQL 语法的查询方式;可读性更好


查询语句和查询方法:

查询语句与查询方法存在着紧密的关系: CLR 本身并不理解查询语句,它只理解查询方法,编译器负责在编译时将查询语句翻译为查询方法,大部分查询方法都有对应的查询语句形式:如 Select() 对应 select OrderBy() 对应 orderby ,部分查询方法目前在 C# 中还没有对应的查询语句:如 Count() Max() 这时只能采用以下替代方案:

1 、查询方法;

2 、查询语句 + 查询方法的混合方式;

一般情况下,建议使用可读性更好的查询语句。


高级查询方法:

聚合类

Count( 返回集合项的数目 )

(1) 、混合模式 : int count = (from p in foxRiver8 where p.Age <= 30  select p).Count();

(2) 、纯粹查询方法模式 : int count = foxRiver8

    .Where(p => p.Age <= 30).Count();

Max( 返回集合中的最大值 ):

(1) 、混合模式: int maxAge = (from p in foxRiver8

  select p.Age).Max();

(2) 、纯粹查询方法模式: int maxAge = foxRiver8

  .Select(p => p.Age).Max();

Min( 返回集合中的最小值 ):

(1) 、混合模式: int maxAge = (from p in foxRiver8

  select p.Age).Min();

(2) 、纯粹查询方法模式: int maxAge = foxRiver8

      .Select(p => p.Age).Min();

Average( 返回集合的平均值 ):

     (1) 、混合模式: double averageAge = (from p in foxRiver8   select p.Age).Average();

     (2) 、纯粹查询方法模式: double averageAge = foxRiver8.Select(p => p.Age)    .Average();

Sum( 返回集合的总和 ):

     (1) 、混合模式: Int sumAge = (from p in foxRiver8

  select p.Age).Sum();

     (2) 、纯粹查询方法模式: int sumAge = foxRiver8

  .Select(p => p.Age) .Sum();

排序类 :

ThenBy( 提供复合排序条件 ):

    (1) 、查询方法 : var q = foxRiver8.OrderBy(p => p.FirstName).ThenBy(p=>p.LasName).ThenBy(p=> p.Age);

     (2) 、查询语句 : var q = from p in foxRiver8        orderby p.FirstName, p.LasName, p.Age select p;

分区类 :

     Take( 提取指定数量的项 )/Skip( 跳过指定数量的项并获取剩余的项 )

int[] numbers = { 1, 2, 3, 4, 5, 6, 7, 8, 9 };

var q = numbers.Skip(1).Take(3);

foreach (var item in q)

{ Console.WriteLine(item); }

说明:跳过前 1 条记录,连续提取 3 条记录,得到 2 3 4

TakeWhile/SkipWhile( 根据指定条件提取项 / 根据指定条件跳过项 )

int[] numbers = { 1, 2, 3, 4, 5, 6, 7, 8, 9 };

var q = numbers.SkipWhile(i=>i % 3 != 0).TakeWhile(i =>i%2!= 0);

foreach (var item in q){Console.WriteLine(item);}

集合类 :

Distinct( 去掉集合中的重复项 ):

int[] factorsOf300 = { 2, 2, 3, 5, 5 };

var uniqueFactors = factorsOf300.Distinct();

输出 : 2 3 5

生成类

Range( 生成一个整数序列 ):

var numbers =Enumerable.Range(1, 10);

foreach (var item in numbers)

{  Console.WriteLine(item);  }

Repeat( 生成一个重复项的序列 ):

var numbers =Enumerable.Repeat(“Beijing 2008”, 10);

foreach (var item in numbers)

{ Console.WriteLine(item); }

注:和其他几类方法不同, Range/Repeat 不是扩展方法,而是普通的静态方法; Range 只能产生整数序列; Repeat 可以产生泛型序列;所有的查询方法都存放在 System.Linq.Enumerable 静态类中。

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
清晰完整PDF版本,是我从网上买来的 共 80MB,分为7个分卷 在 CSDN 上只有我整个是清晰完整的 LINQ 高级编程 .NET 2010 SQL LINQ高级编程 2/7 原价:48.00元 作者:克莱因 译者:李宝 出版社: 清华大学出版社 出版日期: 2009年 ISBN:9787302198857 -------------------------------------------------------------------------------- 本书由数据库专家scott Klein编写,讲述了如何有效地使用LINQ来查询XML、SQL数据库、ADO.NET DataSet和其他数据源,并对此技术进行了更深入的探讨,展示LINQ够显著地改进应用程序的性能。 本书首先介绍TLINQ和Visual Studio 2008、LINQ相关的语言特性以及LINQ查询和LINQ标准查询操作符;然后展示了如何在c#和Visual Basic中使用LINQ to XML编程,以及如何使用LINQ to XML处理其他数据模型;接下来依次介绍LINQ to SQL查询、高级查询概念、LINQ to Entities和LINQ to DataSets。所有这些颇具价值的见解为您提供了强有力的新工具,从而使您能够轻松地扩展和访问数据库中的信息。 内容提要 --------------------------------------------------------------------------------   本书结合具体实例详述了LINQ高级编程所涉及的各个方面。共分为 LINQ概述、LINQ to XML、LINQ to SQL及附录四大部分,每一部分的各个章节结构清晰,层次明显。本书并不是对一种新技术的简单介绍,而是力求使读者通过本书的学习能够立即将LINQ应用到自己的项目开发中。 本书的内容深入浅出,循序渐进,不仅适合LINQ初学者,也可以作为数据库开发人员进阶的参考书。 目录 -------------------------------------------------------------------------------- 第Ⅰ部分 LINQ项目简介  第1章 LINQ项目   1.1 LINQ概述   1.2 标准查询操作符   1.3 LINQ to XML概述   1.4 LINQto SQL概述   1.5 本章小结  第2章 Visual Studio 2008简介   2.1 Visual Studi0 2008   2.2 语言相关的LINQ特性   2.3 本章小结  第3章 LINQ查询   3.1 LrNQ查询简介   3.2 查询语法和方法语法的区别   3.3 使用查询语法和方法语法   3.4 本章小结  第4章 LINQ标准查询操作符   4.1 概述   4.2 标准查询操作符   4.3 使用查询操作符   4.4 本章小结 第Ⅱ部分 LINQ to XML  第5章 理解LINQ to XML   5.1 L]NQ t0XML概述   5.2 LrNQ to XML编程基础   5.3 LINQ to XML编程概念   5.4 LINQtoXML与其他XML技术的比较   5.5 本章小结  第6章 LINQ to XML编程  第7章 LINQ to XML和其他LINQ  第8章 LINQ to XML编程高级  第9章 LINQ to XML和Visual Basic.NET 第Ⅲ部分 LINQ to SQL  第10章 LINQ to SQL概述  第11章 LINQ to SQL查询  第12章 高级查询概念  第13章 实体类  第14章 LINQ to DataSet  第15章 LINQ to SQL高级论题 第Ⅳ部分 附录 作者介绍 -------------------------------------------------------------------------------- SCott K Jein,数据库专家、资深顾问,他对SQL Server、.NET和XML都有着浓厚的兴趣。除本书外,他的著作还包括Professional SQL Server 2005 XML和Professiona/WCF Programming(本书已由清华大华出版社引进并出版,中文版书名为《WCF高级编程》)。除了出版图书之外,Scott Klein还为SOL PASS Community Connector撰写半月刊专题文章,并经常在Wrox网站(www.Wrox.corn)和TopXML网站(www.TopXML.com)上发表文章,在SQL Server和.NET用户群里发言。您可以通过[email protected]与他交流。 文摘 -------------------------------------------------------------------------------- 第Ⅰ部分 LINQ项目简介 第1章 LINQ项目 我经常听说这样的问题,“什么是LINQ?”,“它是用来做什么的?”,“我们为什么需要它?”。第一个问题(以及随后的其他两个问题)的答案是,语言集成查询(LanguageIntegrated QueryLINQ)是一系列标准查询操作符的集合,这些操作符几乎对每一种数据源的导航、过滤和执行操作都提供了底层的基本查询架构。LINQ可查询的数据源包括XML(可使用LINQ to XML,即原来的XLINQ)、关系数据(使用LINQ to SQL,即先前的DLINQ)、AD0.NET DataSets(使用LINQ to DataSet),以及内存中的数据。 理解这项奇妙的新技术的最好方法就是了解一些关于LINQ如何出现以及为什么出现的历史和背景。 虽然人们最早听说LINQ是在2005年秋季,但实际上2003年初微软就启动了LINQ的开发。LINQ的总体目标是使开发人员更容易地处理SQL和XML数据,这主要是因为在关系数据(数据库)及与其通信(即对关系数据进行处理)的编程语言之间没有任何联系,对于XML同样也是如此。 大多数开发人员现在都能理解面向对象(object.oriented,OO)编程及其相关技术和特性,如类、方法、对象等。面向对象编程在过去十多年就已有巨大的发展,但即使在当前,如果要操纵的信息不是使用00方式定义的或本身就不具有00特性,通过O0技术使用和整合这些信息时仍然存在难以逾越的鸿沟。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值