数据操作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反编译出来的代码:

数据操作So easy-LINQ解析

其实在C# 3.0中并没有添加任何新特性,因为对于编译器而言,C# 3.0新特性的代码和以前的代码一样,这对于LINQ也是不例外的。大家可以从IL代码中得出,LINQ表达式是建立在Lambda表达式和扩展方法的基础上的,而Lambda表达式又是建立在委托的基础上的,扩展方法也是属于方法,所以,LINQ的本质还是对方法的调用。

上一篇:linux c语言连接mysql


下一篇:【GoLang】golang中 channel 实现同步 与mutex/atomic 实现同步的讨论