教你如何实现LINQ查询语句

开发 后端
实现LINQ查询语句有三个步骤,他们分别是获取数据源(任何查询的必备工作)、创建查询、执行查询。本文就从这三个方面对实现LINQ查询语句做简单的介绍。

实现LINQ查询语句有三个步骤,他们分别是获取数据源(任何查询的必备工作)、创建查询、执行查询。本文就从这三个方面对实现LINQ查询语句做简单的介绍。

示例:

  1. class IntroToLINQ  
  2. {  
  3.        static void Main()  
  4.        {  
  5.                  //获取数据源(此处由一个数组充当)  
  6.                  int[] numbers = new int[7]{0,1,2,3,4,5,6};  
  7.                  //创建查询(numQuery 是 IEnumerable 类型)  
  8.                  var numQuery = from num in numbers where (num%2) ==
  9.  0 select num;  
  10.                  // 执行查询  
  11.                  foreach(int num in numQuery)  
  12.                  {  
  13.                         Console.write("{0,1}",num);  
  14.                  }  
  15.        }  
  16. }  
  17.  

实现LINQ查询语句之数据源:

上面示例中,数据源是一个数组,隐式支持泛型IEnumerable(T)接口,而支持IEnumerable(T)或派生接口的类型称为"可查询类型"。因此数组即可用LINQ进行查询。

如果数据源还没有作为可查询类型出现在内存中,则LINQ提供程序必须以此方式表示数据源。例如,LINQ to XML将 xml文档加载到可查询的XElement类型中:

  1. using System.Xml.Linq   
  2. XElement contacts = XElement.Load(@"c:\my.xml");//XElement 表示一个xml元素  

在LINQ to SQL 中,必须先创建对象关系映射,然后针对这些对象编写查询。LINQ会处理对象查询与数据库间的通信。

  1. using System.Data.Linq;  
  2. DataContext db = new DataContext(@"c:\northwind.mdf");  

实现LINQ查询语句之创建查询:

查询要先存储在查询变量中,并用查询表达式进行初始化。这个查询变量不执行任何操作也不返回数据,只有在执行查询时用来存储为生成结果而必须的信息。

实现LINQ查询语句之执行查询:

上例中使用foreach的地方就是检索查询结果的地方,它在创建后才执行,因此称为延迟执行,num保存返回的值。

当需要用到聚合函数查询时,则是强制立即执行

  1. var numQuery = from num in numbers where (num%2) == 0 select num;  
  2. int evenNumCount = evenNumCount.Count();  

若普通查询也要立即执行,可以在查询语句后调用ToList()或ToArray()方法。

以上就是对如何实现LINQ查询语句的简单介绍。

【编辑推荐】

  1. 详谈Linq查询结果分析的方法
  2. 简简单单学习Linq查询语法
  3. 详细阐述Linq插入数据的操作方法
  4. 浅析Linq插入数据的实现方法
  5. 简单解决Linq多条件组合问题
责任编辑:阡陌 来源: 爱好者博墅
相关推荐

2009-09-17 10:27:55

linq存储过程

2009-09-14 18:23:59

LINQ嵌套查询

2009-09-15 15:18:40

Linq连接查询

2009-04-28 09:38:53

SQL优化物理查询

2009-09-14 19:14:51

LINQ动态查询

2009-09-15 11:34:47

Linq多条件查询

2010-11-04 09:43:46

LINQ to SQL

2009-08-27 10:22:40

LINQ查询

2009-09-10 10:37:15

LINQ to SQL

2009-09-09 18:03:47

LINQ to SQL

2009-09-10 18:02:23

LINQ to SQL

2009-09-08 11:25:42

Linq foreac

2009-09-07 22:29:04

LINQ组合查询

2012-04-13 10:00:04

LINQ

2009-08-27 13:10:54

LINQ from子句

2009-09-07 22:00:15

LINQ自定义

2009-09-17 13:15:20

LINQ查询

2009-09-16 10:38:43

LINQ查询

2009-09-15 10:46:04

LINQ to SQL

2009-09-16 10:08:06

LINQ查询
点赞
收藏

51CTO技术栈公众号