第二十章 数据访问(In .net4.5) 之 使用LINQ
1. 概述
.net3.5中新添加给C#的LINQ查询,提供了直观便捷的数据查询方式。并且支持多种数据源的查询。
本章介绍标准的LINQ操作,如何用最优的方式使用LINQ 以及 LINQ to XML.
2. 主要内容
2.1 使LINQ可行的语言特性
① 隐式类型(Implicitly typed variables): 使用var标记,由编译器推断类型。也是强命名的。
② 对象初始化语法(Object initialization syntax):用一种简洁的语法进行对象初始化。
var people = new List<Person>
{
new Person
{
FirstName = “John”,
LastName = “Doe”
},
new Person
{
FirstName = “Jane”,
LastName = “Doe”
}
};
③ Lambda表达式:是匿名方法的简化形式。使用 => 符号。
Func<int, int> myDelegate =
delegate(int x)
{
return x * ;
};
Console.WriteLine(myDelegate()); // Displays 42 //用Lambda表达式改写
Func<int, int> myDelegate = x => x * ;
Console.WriteLine(myDelegate()); // Displays 42
④ 扩展方法
扩展方法可以在不继承某类型的情况下给其添加新的行为。扩展方法必须定义在静态类中,用this标记第一个参数。
public static class IntExtensions
{
public static int Multiply(this int x, int y)
{
return x * y;
}
} int x = ;
Console.WriteLine(x.Multiply()); // Displays 6
⑤ 匿名类:同时使用 对象初始化标记 和 隐式类型。
var person = new
{
FirstName = “John”,
LastName = “Doe”
}; Console.WriteLine(person.GetType().Name); // Displays “<>f__AnonymousType0`2”
2.2 使用LINQ查询
int[] data = { , , , , };
var result = from d in data
where d % ==
select d;
foreach (int i in result)
{
Console.WriteLine(i);
}
// Displays 2 8
上述查询式语法可以被改写为方法式语法
var result = data.Where(d => d % == );
*where方法就是 IEnumerable<T>上的扩展方法。
① 标准LINQ操作包括: All, Any, Average, Cast, Count, Distinct, GroupBy, Join, Max, Min, OrderBy, OrderByDescending,
Select, SelectMany, Skip, SkipWhile, Sum, Take, TakeWhile, ThenBy, ThenByDescending, and Where.
int[] data = { , , , , };
var result = from d in data
where d >
orderby d descending
select d;
Console.WriteLine(string.Join(“, “, result)); // Displays 11, 8
* 可以将多个数据源的数据合并操作
int[] data1 = { , , };
int[] data2 = { , , };
var result = from d1 in data1
from d2 in data2
select d1 * d2;
Console.WriteLine(string.Join(“, “, result)); // Displays 2, 4, 6, 4, 8, 12, 10, 20, 30
projection 和 grouping
var result = from o in orders
from l in o.OrderLines
group l by l.Product into p
select new
{
Product = p.Key,
Amount = p.Sum(x => x.Amount)
};
使用Skip和Take实现分页
var pagedOrders = orders
.Skip((pageIndex - ) * pageSize)
.Take(pageSize);
2.3 LINQ如何工作
实现自己的where方法
public static class LinqExtensions
{
public static IEnumerable<TSource> Where<TSource>(
this IEnumerable<TSource> source,
Func<TSource, bool> predicate)
{
foreach (TSource item in source)
{
if (predicate(item))
{
yield return item;
}
}
}
}
2.4 LINQ to Xml
① 查询
XDocument doc = XDocument.Parse(xml);
IEnumerable<string> personNames = from p in doc.Descendants(“Person”)
where p.Descendants(“PhoneNumber”).Any()
let name = (string)p.Attribute(“firstName”)
+ “ “ + (string)p.Attribute(“lastName”)
orderby name
select name;
② 创建
XElement root = new XElement(“Root”,
new List<XElement>
{
new XElement(“Child1”),
new XElement(“Child2”),
new XElement(“Child3”)
},
new XAttribute(“MyAttribute”, ));
root.Save(“test.xml”); //Outputs:
//<Root MyAttribute=”42”>
// <Child1 />
// <Child2 />
// <Child3 />
//</Root>
③ 修改
XElement root = XElement.Parse(xml); XElement newTree = new XElement(“People”,
from p in root.Descendants(“Person”)
let name = (string)p.Attribute(“firstName”) + (string)p.Attribute(“lastName”)
let contactDetails = p.Element(“ContactDetails”)
select new XElement(“Person”,
new XAttribute(“IsMale”, name.Contains(“John”)),
p.Attributes(),
new XElement(“ContactDetails”,
contactDetails.Element(“EmailAddress”),
contactDetails.Element(“PhoneNumber”)
?? new XElement(“PhoneNumber”, “”)
)));
3. 总结
① LINQ, 以一种统一的语法面向多种数据源编写查询语句。
② LINQ用到的一些语言特性包括:implicit typing, object initialization syntax, lambdas, extension methods, and anonymous types。
③ 可以使用查询式语法或者方法式语法来编写LINQ查询。
④ LINQ是延迟执行模式,声明的时候是不会实际执行查询的,第一次遍历开始时才会执行。调用ToList或者Count方法时会立即执行。
⑤ 可以使用LINQ to Xml 来查询、创建 和 修改 xml 数据。
第二十章 数据访问(In .net4.5) 之 使用LINQ的更多相关文章
- 第二十二章 数据访问(In .net4.5) 之 集合
1. 概述 本章内容包括 .net平台中的集合.如何选择集合 以及 如何实现自定义集合. 2. 主要内容 2.1 使用数组(Array) ]; ; x < arrayOfInt.Length; ...
- 第二十一章 数据访问(In .net4.5) 之 序列化
1. 概述 应用程序间传递数据,需要先将数据对象转化为字符流或字节流的形式,然后接收端收到后再转化回原始的数据对象.这就是序列化与反序列化. 本章介绍 .net中的序列化与反序列化.序列化器的种类 以 ...
- 第十八章 数据访问(In .net4.5) 之 I/O操作
1. 概述 本章内容包括 文件操作.流操作.读写网络数据 以及 异步I/O操作. 2. 主要内容 2.1 文件操作 ① 使用 Drive 和 DriveInfo 访问磁盘信息. DriveInfo[] ...
- 第十九章 数据访问(In .net4.5) 之 处理数据
1. 概述 本章介绍 数据库.Json和Xml.web services 三种介质上的数据操作. 2. 主要内容 2.1 数据库 ① 建立连接 .net平台中的数据连接类都继承自DbConnectio ...
- 企业级应用架构(三)三层架构之数据访问层的改进以及测试DOM的发布
在上一篇我们在宏观概要上对DAL层进行了封装与抽象.我们的目的主要有两个:第一,解除BLL层对DAL层的依赖,这一点我们通过定义接口做到了:第二,使我们的DAL层能够支持一切数据访问技术,如Ado.n ...
- 数据访问层的改进以及测试DOM的发布
数据访问层的改进以及测试DOM的发布 在上一篇我们在宏观概要上对DAL层进行了封装与抽象.我们的目的主要有两个:第一,解除BLL层对DAL层的依赖,这一点我们通过定义接口做到了:第二,使我们的DAL层 ...
- JavaScript 数据访问(通译自High Performance Javascript 第二章) [转]
JavaScript 数据访问(通译自High Performance Javascript 第二章) JavaScript 数据访问(翻译自High Performance Javascript ...
- Oracle数据访问组件ODAC的安装方法
Oracle数据访问组件ODAC(Oracle Data Access Components)顾名思义就是用来访问Oracle数据库的小程序.我们可以编程调用这些组件来实现在没有安装Oracle数据库 ...
- Oracle数据访问组件ODAC的安装方法:
Oracle数据访问组件ODAC(Oracle Data Access Components)顾名思义就是用来访问Oracle数据库的小程序.我们可以编程调用这些组件来实现在没有安装Oracle数据库 ...
随机推荐
- Android双击Back退出应用
前言 在app主界面点击back时,通常有以下几种方式进行退出 单击即退出 弹出确认Dialog 再次点击退出程序 个人最喜欢方式3,相比于方式2,不需要再把手指移动到屏幕中央点击Dialog,相比于 ...
- Skill
Skill Yasser is an Egyptian coach; he will be organizing a training camp in Jordan. At the end of ca ...
- 手写堆_C++
一般主程序中拿堆顶元素 x=h[]; h[]=h[top--]; down(); 在堆尾加入元素 h[++top]=x; up(top); 上浮下沉操作 inline void up(int x) { ...
- 单源最短路_SPFA_C++
当我们需要求一个点到其它所有点的最短路时,我们可以采用SPFA算法 代码特别好写,而且可以有环,但是不能有负权环,时间复杂度是O(α(n)n),n为边数,α(n)为n的反阿克曼函数,一般小于等于4 模 ...
- 【翻译】24款界面精美的免费UI工具包
国外网站分享的24款最新的免费UI工具包,喜欢可以收藏哦~ 1. Modern UI Kit Modern UI Kit是一个非常简单时尚的免费用户界面包,提供上百种UI设计元素,可以让设计师轻松利用 ...
- matlab 椭圆方程拟合
拟合椭圆首先要知道各个点的坐标,然和带入如下公式: x = [59 136 58 137 57 137 56 137 55 138 54 139 53 140 52 141 51 142 51 143 ...
- Firefox下载文件时中文名乱码问题
为了形象化,先看几张不同浏览器下下载文件时的效果图: 1:Firefox 36.0.1 2:IE8 3:Chrome 40.0.2214.93 m 4:360 7.1.1.322 很明显在Firefo ...
- 学习练习 java 集合
将1—100之间的所有正整数存放在一个List集合中,并将集合中索引位置是10的对象从集合中移除 package com.hanqi; import java.util.*; public class ...
- ViewPager撤消左右滑动切换功能
ViewPager取消左右滑动切换功能 最近做项目要求某种情况下ViewPager不能滑动,那么我们只需要重写这个方法就可以禁止ViewPager滑动 IndexViewPager.java: imp ...
- STM32F05 学习中............
今天,拿到stm32f05的板子已经三个月了吧,但是没有真的研究过,真的对板子过意不去了...所以决定今天好好的对待我的板子.