LINQ高级编程 笔记

相关资料:http://www.cnblogs.com/lifepoem/archive/2011/12/16/2288017.html

 

1.什么是LINQ

语言集成查询是一系列标准查询操作符的集合,这些操作符几乎对每一种数据源的导航、过滤和执行操作都提供了底层的基本查询架构。Linq  可查询的数据源包括XML(可使用LINQ to XML)、关系数据(使用LINQ to SQL)、ADO.NET DataSets(使用 LINQ to DataSet)以及内存中的数据。

2.LINQ的优势

a)一个可用于任何.NET编程语言的查询操作符集合,可以使用同一种语法为数据库、XML、或者内存中的数据编写查询,同时还得到了附加的好处,即IntelliSense和编译时类型检查;

3.LINQ 在查询目录上的运用例子

1  DirectoryInfo di = new DirectoryInfo("C:\\");
2             var dirName = from dir in di.GetDirectories()
3                            orderby dir.Name descending 
4                            select new { dir.Name };
5             ViewBag.fileList = dirName.ToList();

4.LINQ在查询系统中所有进程上的运用的例子

1  //linq在系统进程查询上的运用
2             var procQuery = from p in Process.GetProcesses()
3                             orderby p.WorkingSet64 descending
4                             select new { p.ProcessName, p.Id, p.WorkingSet64 };
5             ViewBag.procList = procQuery.ToList();

 5.into关键字

在我们前面查询表达式的例子中,select关键字的出现也就意味着查询的结束了。而into关键字让我们在结果投影之后还可以继续我们的查询,它是对分步构建查询表达式的一种简写方式。现在我们可以使用into关键字来重写上例中的查询:

 IEnumerable<string> query =
                    from n in names
                    select n.Replace("a", "").Replace("e", "").Replace("i", "")
                            .Replace("o", "").Replace("u", "")
                    into noVowel
                    where noVowel.Length > 2
                    orderby noVowel
                    select noVowel;   // Result: Dck, Hrry, Mry

我们只能在select和group子句后面使用into关键字,它会重新开始一个查询,让我们可以继续引入where, orderby和select子句。尽管表面上看,我们重新创建了一个新的查询,但当上面的查询被翻译成方法语法时,它只是一个查询,一个链接了多个运算符的查询,所以上面的写法不会造成性能问题。

6.

渐进式查询创建方式可以通过在一个查询中嵌入另一个查询来改写,这样可以把多个查询组合成单个查询,即:

var tempQuery = tempQueryExpr

var finalQuery = from … in (tempQuery)

可以改写为:

var query = from … in (tempQueryExpr)

上面两种方式以及into关键字的工作方式是一样的,编译器都会把他们翻译成一个链接查询运算符。请看下面的示例:

 string[] names = { "Tom", "Dick", "Harry", "Mary", "Jay" };
 
            // 渐进式查询(Progressive query building)
            IEnumerable<string> query =
                from n in names
                select Regex.Replace(n, "[aeiou]", "");
 
            query = from n in query where n.Length > 2 orderby n select n;
 
            // 用包装查询方式进行改写(Wrapping Queries)
            IEnumerable<string> query2 =
                from n1 in
                    (
                        from n2 in names
                        select Regex.Replace(n2, "[aeiou]", "")
                    )
                where n1.Length > 2
                orderby n1
                select n1;
 
            // 与上面等价的方法语法
            IEnumerable<string> query3 = names
                .Select(n => Regex.Replace(n, "[aeiou]", ""))
                .Where(n => n.Length > 2)
                .OrderBy(n => n);

7.匿名类型上面我们自己定义了类型TempProjectionItem来存放查询的结果。通过使用匿名类型,我们可以省去这种中间类型的定义,而由编译器来帮我们完成:

 var intermediate = from n in names
                               select new
                               {
                                   Original = n,
                                   Vowelless = Regex.Replace(n, "[aeiou]", "")
                               };
            IEnumerable<string> query = from item in intermediate
                                        where item.Vowelless.Length > 2
                                        select item.Original;

需要注意的是,因为匿名类型的确切类型名是由编译器自动产生的,因此intermediate的类型为:IEnumerable <random-compiler-produced-name> 。我们来声明这种类型的唯一方式就是使用var关键字,这时,var不只是更加简洁,而且也是必需的手段。

8.let关键字let关键字让我们可以在保持范围变量的同时引入新的查询变量。比如上面的示例,我们可以用let关键字作如下改写:

string[] names = { "Tom", "Dick", "Harry", "Mary", "Jay" };
            var query = from n in names
                        let Vowelless = Regex.Replace(n, "[aeiou]", "")
                        where Vowelless.Length > 2
                        select n;   //正是因为使用了let,此时n仍然可见

let关键字非常灵活和方便,就像例子看到的那样。而且,我们可以使用多个let关键字,并且后面的 let表达式可以引用前一个let关键字引入的变量。

转载于:https://www.cnblogs.com/meiCode/p/5192362.html

清晰完整PDF版本,是我从网上买来的 共 80MB,分为7个分卷 在 CSDN 上只有我整个是清晰完整的 LINQ 高级编程 .NET 2010 SQL LINQ高级编程 6/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用户群里发言。您可以通过ScottKlein@SalXml.com与他交流。 文摘 -------------------------------------------------------------------------------- 第Ⅰ部分 LINQ项目简介 第1章 LINQ项目 我经常听说这样的问题,“什么是LINQ?”,“它是用来做什么的?”,“我们为什么需要它?”。第一个问题(以及随后的其他两个问题)的答案是,语言集成查询(LanguageIntegrated Query,LINQ)是一系列标准查询操作符的集合,这些操作符几乎对每一种数据源的导航、过滤和执行操作都提供了底层的基本查询架构。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、付费专栏及课程。

余额充值