LINQ查询全面介绍

开发 后端
这里介绍LINQ查询,LINQ是Visual Studio 2008及其以后版本中提供的功能,将强大的查询扩展到C#和VB.NET语言语法之中。

在向大家详细介绍LINQ查询之前,首先让大家了解下LINQ提供了标准、简单的模式来查询和更新数据,然后全面介绍LINQ查询。

LINQ是Visual Studio 2008及其以后版本中提供的功能,将强大的查询扩展到C#和VB.NET语言语法之中。LINQ提供了标准、简单的模式来查询和更新数据,同时还允许程序开发人员进行扩展,支持任何类型的数据存储。Visual Studio 2008包含了LINQ提供者程序集,能够对.NET Framework集合,内存中的对象数组,SQL Server数据库,ADO.NET Dataset和XML文档进行语言集成的查询。另外,我们也可以自己编写LINQ提供者,提供对任何类型数据的查询,只要实现了IEnumerable或者IEnumerable<T> (C#)或 IEnumerable (Of T) (Visual Basic)的数据类型,都可以进行使用LINQ进行操作。我们可以使用完全相同的语法查询SQL数据库、XML文档、ADO.NET的Dataset(DataTable)、内存中的集合对象,以及任何支持LINQ的远程或者本地数据源。在LINQ查询中,只与对象打交道,因此,可以完全不需要知道数据存储的数据源,而且采用的编程模型和语法也完全相同。

所有的LINQ查询基本上都是由3个基本的操作组成:得到数据源,创建查询和执行查询3个过程。数据的获得是在执行查询的时候完成的。

  1. NorthWindDataContext NorthWind = new NorthWindDataContext(); 

是得到数据源

  1. var query = from c in NorthWind.
    Customers where 
    c.Country == "USA" select new { c.Country, c.CompanyName }; 

是创建查询,此时并没有对数据执行任何操作

  1. GridView2.DataSource = query;  
  2. GridView2.DataBind(); 

在数据绑定时,才真正得到数据。

但是,有的查询需要立即执行,将结果放在内存中,可以调用查询或者查询变量的ToList<(Of <TSource>)> 或者 ToArray<(Of <TSource>)>方法。例如:

  1. var query2 = from c in NorthWind.Customers where c.Country == 
    "USA" select new { c.Country, c.CompanyName };  
  2. var query3 = query2.ToList(); 

好,运行本程序可能需要采用模拟或者调整Excel.exe的权限,另外注意:使用之前需要引用COM:Microsoft Office 11.0 Object Library,如果引用列表中没有,需要自行添加 C:\Program Files\Microsoft Office\OFFICE11\EXCEL.EXE)。以上介绍LINQ查询。

【编辑推荐】

  1. Linq表达式树简单介绍
  2. Linq和dLinq区别剖析
  3. Lambda表达式和Linq查询浅析
  4. Linq Lambda表达式概括
  5. Linq查询本质简单分析
责任编辑:佚名 来源: IT168
相关推荐

2009-09-17 13:15:20

LINQ查询

2009-09-16 10:48:32

LINQ查询操作

2009-09-17 17:03:13

LINQ动态查询

2009-09-07 17:05:10

LINQ进行查询

2009-09-15 09:39:38

LINQ查询架构

2009-09-18 16:20:36

LINQ基础

2009-09-09 14:40:43

Linq to sql

2009-09-16 17:21:53

LINQ遍历

2009-09-11 12:13:40

LINQ to SQL

2009-09-16 16:55:07

LINQ to XML

2009-09-16 17:41:56

Linq延时执行

2009-09-18 13:53:09

LINQ工具集

2009-09-18 17:17:58

LINQ模型

2009-09-16 10:58:13

Linq数据分组

2009-09-16 11:19:48

Linq Select

2009-09-09 14:20:49

LINQ To Luc

2009-09-18 09:25:06

LINQ Framew

2009-09-08 13:07:15

介绍Linq to S

2009-09-11 09:41:19

LINQ to SQL

2009-09-10 17:30:15

LINQ Where子
点赞
收藏

51CTO技术栈公众号