数据操作So easy-LINQ解析
1、LINQ是什么?
LINQ是Language Integrated Query的缩写,即“语言集成查询”的意思。LINQ的提出就是为了提供一种跨越各种数据源的统一的查询方式,它主要包含4个组件--Linq to Objects、Linq to XML、Linq to DataSet和Linq to SQL。
下面简单的介绍一下LINQ的4个组件。
Linq to SQL组件:它可以查询基于关系数据库的数据。其中,微软只实现了对SQL Server数据库的查询,包括对其中数据进行查询、修改和删除等操作。
Linq to DataSet组件:它可以查询DataSet对象中的数据,并能对数据进行增删改查等操作。
Linq to XML组件:该组件可以查询XML文件,在它被提出来之前,C#中使用XPath来对XML进行查询,但该工具没有Linq to XML来得简洁。
Linq to Object组件:这个组件可以查询集合数据,如数组或List等。
2、LINQ好在哪里?
好的地方:LINQ使对数据源的操作变得更加简单、方便和易于理解。
2.1 查询表达式
在说明LINQ的好处之前,需要先了解“查询表达式”。查询表达式必须以from子句开头,并且必须以select或group子句结尾,在第一个from子句和最后一个select或group子句之间,可以包含一个或多个where子句、orderby、join子句。其形式非常类似于SQL语言,只是书写倒了过来。
//查询表达式 var queryExp= from s in collection
select s;
//查询表达式还有另外一种表达方式,即“点标记方式”,var queryExp=collection.Select(s=>s);
至于选择什么方式,就看程序员个人的习惯了。
2.2 使用Linq to Objects查询集合
在LINQ提出之前,一般使用for和foreach查询集合,但这种方式没有LINQ to Objects来得简洁,且不容易添加筛选条件。
//创建查询表达式来获得集合中为偶数的元素
var queryResults= from item in collection
where item% ==
select item;
从以上代码可以看出,使用Linq to Objects来查询集合对象,代码更加简洁了。而且LINQ还方便添加筛选条件,只需要在where子句中添加即可。
2.3 使用Linq to XML 查询XML文件
//创建查询,获取名字为“李四”的元素
var queryResults=from element in xmlDoc.Elements("Person")
where element.Element("Name").Value=="李四"
select element;
从以上代码可以看出,使用Linq to XML查询XML文件,代码明显简洁了很多,只需要一个查询表达式即可。
Linq to DataSet的例子这里就不写了,它的使用方式类似于Linq to Object,只是Linq to DataSet查询的不是集合对象而是DataSet对象。
3、理解LINQ的本质
首先我们先运行一段代码,并用Reflector进行查看,内部是怎么实现的。
class Program
{
static void Main(string[] args)
{
List<int> inputArray=new List<int>();
for (int i = ; i < ; i++)
{
inputArray.Add(i);
}
Console.WriteLine("使用Linq方法来对集合对象查询、查询结果为:");
LinqQuery(inputArray);
Console.ReadKey();
} private static void LinqQuery(List<int> inputArray)
{
var queryResults = from item in inputArray
where item% ==
select item;
foreach (int queryResult in queryResults)
{
Console.Write(queryResult+" ");
}
}
}
再来看看Reflector反编译出来的代码:

其实在C# 3.0中并没有添加任何新特性,因为对于编译器而言,C# 3.0新特性的代码和以前的代码一样,这对于LINQ也是不例外的。大家可以从IL代码中得出,LINQ表达式是建立在Lambda表达式和扩展方法的基础上的,而Lambda表达式又是建立在委托的基础上的,扩展方法也是属于方法,所以,LINQ的本质还是对方法的调用。
数据操作So easy-LINQ解析的更多相关文章
- Atitit.数据操作dsl 的设计 ---linq 方案
Atitit.数据操作dsl 的设计 ---linq 方案 1.1. sql与api方式1 1.2. Linq方案与stream方案的选择,1 1.3. 前缀表达式 vs 中缀表达式1 1.4. 要不 ...
- Linq解析带命名空间、前缀、Soap格式的XML
关于XML,经常会用到,XML有一般的,同样也有二般的,更不要觉得会操作基础的XML就觉得自己已经精通XML操作,文中是对解析XML的方法进行介绍 1. 一般XML <?xml version= ...
- [读书笔记]C#学习笔记六: C#3.0Lambda表达式及Linq解析
前言 最早使用到Lambda表达式是因为一个需求:如果一个数组是:int[] s = new int[]{1,3,5,9,14,16,22};例如只想要这个数组中小于15的元素然后重新组装成一个数组或 ...
- C#学习笔记五: C#3.0Lambda表达式及Linq解析
最早使用到Lambda表达式是因为一个需求:如果一个数组是:int[] s = new int[]{1,3,5,9,14,16,22};例如只想要这个数组中小于15的元素然后重新组装成一个数组或者直接 ...
- StackExchange.Redis帮助类解决方案RedisRepository封装(字符串类型数据操作)
本文版权归博客园和作者本人共同所有,转载和爬虫请注明原文链接 http://www.cnblogs.com/tdws/tag/NoSql/ 目录 一.基础配置封装 二.String字符串类型数据操作封 ...
- Django数据操作F和Q、model多对多操作、Django中间件、信号、读数据库里的数据实现分页
models.tb.objects.all().using('default'),根据using来指定在哪个库里查询,default是settings中配置的数据库的连接名称. 外话:django中引 ...
- Entity Framework 5.0系列之数据操作
Entity Framework将概念模型中定义的实体和关系映射到数据源,利用实体框架可以将数据源返回的数据具体化为对象:跟踪对象所做的更改:并发处理:将对象更改传播到数据源等.今天我们就一起讨论如何 ...
- SNMP常用数据操作
SNMP常用数据操作 snmp编程中常见的数据类型基本上就是integer32/oct_str(字节数组)/counter64/timeticks/dateAndTime这些.很多其它的比如Truth ...
- oracle-2-sql数据操作和查询
主要内容: >oracle 数据类型 >sql建表和约束 >sql对数九的增删改 >sql查询 >oracle伪例 1.oracle的数据类型 oracle数据库的核心是 ...
- MapObject shape数据操作
利用MO 的GeoDataset .DataConnection Recordset 进行数据操作 在MO中.使用GeoDataset对象和DataConnection 对象来连接和读取地理数据. ...
随机推荐
- makefile 中 $@ $^ %< 使用
这篇文章介绍在LINUX下进行C语言编程所需要的基础知识.在这篇文章当中,我们将会学到以下内容: 源程序编译 Makefile的编写 程序库的链接 程序的调试 头文件和系统求助 1.源程序的编译 在L ...
- aix挂载centos 的nfs
centos作为服务器,提供nfs文件系统,aix作为客户端,挂载centos的指定目录 (1)NFS的安装配置:centos 5 : yum -y install nfs-utils portmap ...
- VMWare虚拟机USB连接问题
错误31:连接到系统上的设备没有发挥作用 原文链接 描述 常用 VMware 虚拟机的有事应该遇到这种情况,就是装完 VMware ,启动时 VMware 下面会有个黄框中有" USB di ...
- Floyd-Warshall算法的理解
Floyd算法可以求图内任意两点之间的最短路径,三重循环搞定,虽然暴力,但是属于算法当中最难的动态规划的一种,很有必要理解. 花了一晚上和半个下午专门看这个,才看个一知半解,智商被碾压没办法. 我一直 ...
- Spring笔记之(一)初探
对spring框架的学习我是从模拟它的简单实现开始,这样也易于领悟到它的整个框架结构,以下是简单实现的代码: 配置文件:spring.xml <?xml version="1.0&qu ...
- 使用Hadoop打造私有云盘之API操作
项目介绍:使用hadoop实现云盘的增删读获取列表功能,hadoop不支持数据修改,特性是一次写入多次读取.主流的网盘也不支持该功能.今天我们用hdfs的FileSystem实现这些操作. 1.上传功 ...
- 第三周作业、实时操作系统µC/OS介绍及其它内容
作业要求 见<实时控制软件设计>第三周作业 1 阅读笔记--µC/OS 1.1 基本介绍 µC/OS是由Micrium公司研发的实时操作系统,以µC/OS-II或µC/OS-III为内核, ...
- IOS 中runtime 不可变数组__NSArray0 和__NSArrayI
IOS 中runtime 不可变数组__NSArray0 和__NSArrayI 大家可能都遇到过项目中不可变数组避免数组越界的处理:runtime,然而有时候并不能解决所有的问题,因为类簇不一样 # ...
- Redis_基本类型介绍和指令___1
1.Key(键) 主要的方法: ->set key(设置) ->get key(得到) ->del key(删除) ->exitst key(存在) -> expires ...
- Delphi调用C++写的dll示例
最近做一个读市民卡的项目,读卡器公司提供的读市民卡dll是用C++写的. 下面记录一些自己的心得,供需要的朋友参考. 声明dll函数要加上stdcall关键字,否则可能会报地址非法的错误. 代码: u ...