LINQ嵌套查询实现浅析
创始人
2024-06-07 00:31:25
0

LINQ嵌套查询是如何实现的呢?那么下面我们看看具体的操作是怎么样的,它对于我们的实际开发实践有什么帮助,那么让我们开始吧。

LINQ嵌套查询应用实例:

如果我们需要取出市场部的所有员工,在以往的O/R Mapping框架中,往往需要取两次(我们不考虑存在映射关系的情况),一次是取出市场部的编号,再使用编号来取出所有员工。LINQ给我们提供了更好的解决办法,我们可以这样操作:

  1. var query = from employee in dbdata.Employees   
  2. where employee.DepId ==  
  3.  
  4. (from department in dbdata.Departments   
  5. where department.DepName == "市场部" 
  6.  
  7.  select department ).Single().DepId  
  8.  
  9. select employee;  

这里我们使用了嵌套查询来完成,这句话在执行的时候,LINQ嵌套查询被转换成了SQL的嵌套查询:

  1. SELECT [t0].[EmployeeId], [t0].[DepId],   
  2. [t0].[EmployeeName], [t0].[EmployeeSalary]   
  3. FROM [dbo].[Employee] AS [t0]   
  4. WHERE [t0].[DepId] = (  
  5. SELECT [t1].[DepId] FROM [dbo].[Department] AS [t1]   
  6. WHERE [t1].[DepName] = @p0) 

当然,在这里,我们不必那么麻烦,只需要使用已经存在的实体关系,就可以轻松的完成:

  1. var query = from employee in dbdata.Employees   
  2. where employee.Department.DepName == "市场部" 
  3.  
  4. select employee;  

不过,这和刚才的查询却有本质的差别,我们来看看这里,LINQ转换成什么样的SQL语句了:

  1. SELECT [t0].[EmployeeId], [t0].[DepId],   
  2. [t0].[EmployeeName], [t0].[EmployeeSalary]  
  3.  FROM [dbo].[Employee] AS [t0] LEFT OUTER JOIN [dbo].  
  4. [Department] AS [t1] ON [t1].[DepId] = [t0].[DepId]   
  5. WHERE [t1].[DepName] = @p0 

这里,转换出来的并不是嵌套的SQL语句,而被转换成了左连接查询,可以看出,嵌套查询是我们在特殊的情况下,可以使用的一个利器。

LINQ嵌套查询的基本内容就向你介绍到这里,希望对你了解和学习LINQ嵌套查询有所帮助。

【编辑推荐】

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