教你如何实现LINQ查询语句
创始人
2024-06-07 07:40:28
0

实现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多条件组合问题

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...