语言集查询(Language Integrated Query, LINQ)集成了C#编程语言中的查询语法,可以用同样的语法访问不同的数据源。LINQ提供了不同数据源的抽象层,可以使用相同的语法。

.NET Language Integrated Query (LINQ):不采用特定于关系数据库或者XML的专有方案,而采用通用方案解决各种信息源的访问与整合问题。个人感觉这是LINQ最大的特点,除此之外,在LINQ中,查询成为编程语言的一个组成部分,这使得查询表达式可以得到很好地编译时语法检查,丰富的元数据,智能感知等强类型语言的好处。


下面先来看一个实例,对LINQ有一个感性的认识:

namespace ConsoleApplication.Linq
{
class FirstLinq
{
public static void Main()
{
String[] names = { "Burke", "Connor", "Frank", "Everett", "Albert", "George", "Harris", "David" };

Console.WriteLine("使用LINQ进行集合的查询:");
IEnumerable<String> query = from s in names
where s.Length == 5
orderby s
select s.ToUpper();
foreach (String str in query)
{
Console.WriteLine(str);
}

Console.WriteLine("使用基于方法的查询:");
//Where、OrderBy、Select方法的参数均为Lambda表达式,即一个匿名函数
IEnumerable<String> anotherQuery = names
.Where(s => s.Length == 5)
.OrderBy(s => s)
.Select(s => s.ToUpper());
foreach (String str in anotherQuery)
{
Console.WriteLine(str);
}
}
}
}


运行结果如下:

LINQ初步_xml


可以看到查询操作符的实质其实是方法的调用。

查询表达式必须以form子句开头,以select或group子句结束。在这两个子句之间,可以使用where、orderby、join、let和其他from子句。

查询操作符是LINQ中的另外一项重要设施,LINQ使用扩展方法来定义查询操作符,例如Where操作符(Where方法的签名):

public static IEnumerable<TSource>Where<TSource>(this IEnumerable<TSource> source, Func<TSource,bool> predicate);

普通的方式来调用扩展方法:

IEnumerable<String> query = Enumerable.Where(names,s => s.Length == 5);

C#允许我们使用如下的方式来调用扩展方法:

IEnumerable<String> query = names.Where(s=> s.Length == 5);

下面解释一下什么是扩展方法:

扩展方法使您能够向现有类型“添加”方法,而无需创建新的派生类型、重新编译或以其他方式修改原始类型。扩展方法是一种特殊的静态方法,但可以像扩展类型上的实例方法一样进行调用。扩展方法被定义为静态方法,但它们是通过实例方法语法进行调用的。它们的第一个参数指定该方法作用于哪个类型,并且该参数以 this 修饰符为前缀。




所有LINQ查询操作都由三个不同的操作组成:

(1)获取数据源。

(2)创建查询。

(3)执行查询。

在上一个示例中,由于数据源是数组,因此它隐式支持泛型IEnumerable<T>接口。这一事实意味着该数据源可以用LINQ进行查询。查询在foreach语句中执行,因此,foreach需要IEnumerable或IEnumerable<T>。支持IEnumerable<T>或派生接口的类型称为可查询类型。可查询类型不需要进行修改或特殊处理就可以用作LINQ数据源。


如果数据源还没有作为可查询类型出现在内存中,则LINQ提供程序必须以可查询类型表示数据源。例如:LINQ to XML将XML文档加载到可查询的XElement类型中;在LINQ to SQL中,首先手动或使用对象关系设计器在设计时创建对象关系映射。针对这些对象编写查询,然后由LINQ to SQL在运行时处理与数据库通信。

具体说来,

LINQ to SQL将SQL的模式信息集成到CLR元数据中,自然地将面向对象领域的对象与关系型数据库中的表格数据相互转化,从而允许我们使用LINQ来便捷地访问关系数据库。

LINQ to SQL是作为ADO.NET的一个重要组件,而非完全替代品。

 

LINQ to XML 提供使用 .NET 语言集成查询 (LINQ)Framework 的内存中 XML 编程接口。 LINQ to XML 使用最新的 .NET Framework 语言功能,相当于更新的和重新设计的文档对象模型 (DOM) XML 编程接口。

个人感觉LINQ最大的特色就是:LINQ 系列技术提供了针对对象 (LINQ toObjects)、关系数据库 (LINQ to SQL) 和 XML (LINQ to XML) 的一致查询体验。