LINQ查询方式的探寻
创始人
2024-06-07 00:30:24
0

LINQ投影以及使用LINQ的扩展方法是我们经常使用LINQ查询方法,那么关于LINQ投影以及使用LINQ的扩展方法有什么需要我们注意的方面么?让我们来看看具体的实现。

1、LINQ查询之LINQ投影

如果说刚才的查询,还只是很简单的查询,那么结合匿名类来实现投影查询,则是LINQ提供的一个利器,这种方法非常灵活,同时也满足了我们绝大部分的查询需求。下面我们来看一个例子:我们需要查询出部门工资的总和,怎么做呢?

  1. var query = from department in dbdata.Departments  
  2.  
  3.                 select  new{ depid = department.DepId, depname=  
  4.  
  5. department.DepName, depsalary =  
  6.  
  7. department.Employees.Sum(e => e.EmployeeSalary) };  

这句查询语句中,在new关键字后面生成了一个匿名类,这个类有三个属性,分别是 depid,depname和depsalary,其中,depsalary是经过计算获得,这句话被转换成:

  1. SELECT [t0].[DepId] AS [depid], [t0].[DepName] AS [depname],  
  2.  
  3. (SELECT SUM([t1].[EmployeeSalary]) FROM [dbo].[Employee]  
  4.  
  5. AS [t1] WHERE [t1].[DepId] = [t0].[DepId] ) AS [depsalay]  
  6.  
  7. FROM [dbo].[Department] AS [t0]  

好优雅的代码,实在是太方便了。

2、LINQ查询之使用LINQ的扩展方法

LINQ提供了很多扩展方法,方便我们做各种查询,我们来看几个典型的扩展方法:

a)使用LINQ的扩展方法之Average、Max

  1. Decimal x = dbdata.Employees.Average(e => e.EmployeeSalary);  
  2.  
  3. Decimal y = dbdata.Employees.Max(e => e.EmployeeSalary);  

这是计算出员工的平均工资与最大工资,你不需要编写任何的SQL语句,Orcas中提供的LINQ到SQL对象关系映射器会处理获取,跟踪,和更新映射到你的数据库数据定义和存储过程的对象。你只要使用任何LINQ扩展方法对结果进行过滤和构形即可,LINQ到SQL会执行获取数据所需的SQL代码(注意,上面的 Average和Max 扩展方法很明显地不会从数据表中返回所有的数据行,它们会使用TSQL的聚合函数来计算数据库中的值,然后只返回一个标量值)。

b)使用LINQ的扩展方法之Where、OrderBy

有时候,我们只对某张表做简单的查询和排序,那么,这个时候不必写冗长的LINQ语句,直接使用LINQ扩展方法即可,如:

  1. var query = dbdata.Employees.  
  2.  
  3. Where(e => e.EmployeeSalary > 2000).  
  4.  
  5. OrderBy(e => e.EmployeeName);  

这里使用了Lambda语法,这句话被转换成以下的SQL语句:

  1. SELECT [t0].[EmployeeId], [t0].[DepId], [t0].[EmployeeName],  
  2.  
  3. [t0].[EmployeeSalary] FROM [dbo].[Employee] AS [t0]  
  4.  
  5. WHERE [t0].[EmployeeSalary] > @p0 ORDER BY [t0].[EmployeeName]  

以上是通过利用由Lambda提供的对表达式树支持,以及IQueryable接口来实现的,代码干净整洁。

C)使用LINQ的扩展方法之Take、Skip

对于大批量的数据处理,一直是开发人员的比较头疼的事情,微软在.NET1.1到2.0中的Gridview等控件,对大批量数据的处理上一直都不是很理想,LINQ对于大批量数据的处理,可以很好的解决这个方面的问题。

  1. var query = dbdata.Employees.Skip(10).Take(10); 

这句话表示跳过该表的10条记录,再取10条,也就是取第11至20条记录,转换成SQL语句如下:

  1. SELECT [t1].[EmployeeId], [t1].[DepId], [t1].[EmployeeName],  
  2.  
  3. [t1].[EmployeeSalary] FROM (SELECT ROW_NUMBER()  
  4.  
  5. OVER (ORDER BY [t0].[EmployeeId], [t0].[DepId], [t0].[EmployeeName],  
  6.  
  7. [t0].[EmployeeSalary]) AS [ROW_NUMBER], [t0].[EmployeeId], [t0].[DepId],  
  8.  
  9. [t0].[EmployeeName], [t0].[EmployeeSalary] FROM [dbo].[Employee]  
  10.  
  11. AS [t0]) AS [t1] WHERE [t1].[ROW_NUMBER] BETWEEN @p0 + 1 AND  
  12.  
  13. @p0 + @p1 ORDER BY [t1].[ROW_NUMBER]  

从以上这句SQL语句来看,最消耗性能分页操作完全交给了数据库操作,其处理的机制不再像Gridview控件的分页,是将数据全部取出,然后再进行分页显示,因此效率上要高了很多。

D)使用LINQ的扩展方法之ToList和ToArray

在默认情况下,查询结果的数据类型是IEnumerable类型,可能很多开发人员并不习惯这个类型,而更加喜欢集合或者是数组,那么没关系,可以使用ToList或者是ToArray来将查询结果转换成集合或者数组。在这里,我们需要知道的是:使用查询语句查询结果的时候,实际上并没有真正操作数据库,这里是运用的延迟加载的机制,如果不希望使用延迟加载,而是需要立刻知道查询的结果时,使用ToList或者是ToArray便可以做到。这是非常有用的机制。比如我们需要显示两个部门的员工时,部门可以先取出放置在List中,然后再依次取出各个部门的员工,这时访问的效率要高一些,因为不需要每次都访问数据库去取出部门。

LINQ查询之LINQ投影以及使用LINQ的扩展方法的使用就向你介绍到这里,希望对你了解和学习LINQ查询遗迹LINQ投影和使用LINQ的扩展方法有所帮助。

【编辑推荐】

  1. LINQ模糊查询学习体验浅析
  2. LINQ To SQL和ORM的理解浅析
  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 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...