返回顶部
首页 > 资讯 > 精选 >LINQ如何实现子查询和延迟执行编程
  • 840
分享到

LINQ如何实现子查询和延迟执行编程

2023-06-17 22:06:08 840人浏览 泡泡鱼
摘要

这篇文章将为大家详细讲解有关LINQ如何实现子查询和延迟执行编程,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。LINQ子查询 LINQ子查询是一个包含了另外一个查询的Lambda表达式的查询. 以下的例子

这篇文章将为大家详细讲解有关LINQ如何实现子查询和延迟执行编程,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

LINQ子查询

LINQ子查询是一个包含了另外一个查询的Lambda表达式的查询. 以下的例子使用了一个LINQ子查询来针对篮球明星的last name排序:

string[] players = { "Tim Ducan", "Lebrom James", "Kobe Byrant" };   IEnumerable<string> q = players.OrderBy (m => m.Split().Last());

在这其中, Last是一个LINQ子查询, q则代表了一个外部查询.

在LINQ子查询中, 你可以在Lambda表达式的右边使用任何可行的C#表达语法.LINQ 子查询只是一个简单的C#表达式, 这意味着所有适用于LINQ子查询的规则都可以推导到Lambda表达式上.

以下的查询取得一个字符数组中所有满足长度等于最小长度的字符序列:

string[] names = { "James","Jack","Landy","C.Y","Jay" };     IEnumerable<string> q = names       .Where (n => n.Length ==          names.OrderBy (n2 => n2.Length)               .Select  (n2 => n2.Length).First( )       );     foreach(var s in q)     {         Console.WriteLine(s); //C.Y , Jay    }

对于LINQ子查询, 可以引用到外部的Lambda参数或者是迭代变量(在复合查询中). 例如上述的例子中, 如果OrderBy使用的表达式改为(n => n.Length)而不是用n2的话将会得到一个错误信息:

A local variable named ‘n’ cannot be declared in this scope because it would give a different meaning to ‘n’, which is already used in a ‘parent or current’ scope to denote something else.

针对这个例子, 我们可以看到对应的复合查询写法:

IEnumerable<string> q =       from n in names       where n.Length ==         (from n2 in names          orderby n2.Length          select n2.Length).First( )       select n;

外部迭代变量n在LINQ子查询范围内是可见的, 因此我们不能将它重用为LINQ子查询内部的迭代变量.

LINQ子查询会在对应的Lambda表达式被执行的时候来执行, 其执行取决于外部查询, 也可以说是由外到里来处理的. 本地查询完全遵循这个模型, 但是解释型查询(例如LINQ to sql)则仅仅是概念上遵循而已.

之前的查询我们还可以使用一种更加简洁的写法:

IEnumerable<string> q =       from n in names       where  n.Length ==              names.OrderBy (n2 => n2.Length).First().Length       select n;

如果使用Min聚合函数, 还可以进一步简化:

IEnumerable<string> q =           from n in names           where n.Length == names.Min (n2 => n2.Length)           select n;

实际上, 由于n2.Length在外部查询循环的时候每次都会重新计算, 这在某些情况下可能会引起效率问题, 避免这个问题, 我们可以将LINQ子查询分离出来:

int len = names.Min (n => n.Length);           IEnumerable<string> query = from   n in names                                 where  n.Length == len                                 select n;

子查询和延迟执行

在LINQ子查询中的返回单一元素或者聚合类操作符, 例如first或者Count, 并不会强制外部查询立即执行, 也就说外部查询依然拥有延迟执行的能力. 这是因为LINQ子查询是被间接调用的 – 如果是本地查询则是通过代理(delegate), 如果是解释性查询则是通过表达树(expression tree).

一个有趣的现象是当你的LINQ子查询中包含一个Select表达式的时候, 如果是本地查询, 你实际上是将其发散成一序列的查询 – 并且每一个都拥有延迟执行的能力. 这个影响是透明的, 因为它可以显著提高效率.

关于“LINQ如何实现子查询和延迟执行编程”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

--结束END--

本文标题: LINQ如何实现子查询和延迟执行编程

本文链接: https://lsjlt.com/news/293786.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • LINQ如何实现子查询和延迟执行编程
    这篇文章将为大家详细讲解有关LINQ如何实现子查询和延迟执行编程,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。LINQ子查询 LINQ子查询是一个包含了另外一个查询的Lambda表达式的查询. 以下的例子...
    99+
    2023-06-17
  • C# Linq延迟查询的执行实例代码
    C# Linq延迟查询 在定义linq查询表达式时,查询是不会执行,查询会在迭代数据项时运行。它使用yield return 语句返回谓词为true的元素。 var names ...
    99+
    2024-04-02
  • Linq如何实现延迟加载
    小编给大家分享一下Linq如何实现延迟加载,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!Linq延迟加载在查询某对象时,实际上你只查询该对象。不会同时自动获取这个...
    99+
    2023-06-17
  • SpringBootEvent事件如何实现异步延迟执行
    目录SpringBoot Event 事件实现异步延迟执行使用它只需要三样东西总结SpringBoot Event 事件实现异步延迟执行 Spring的事件(Application ...
    99+
    2023-02-14
    SpringBoot Event事件 异步延迟执行 SpringBoot实现异步
  • 批处理如何实现延迟执行命令
    这篇文章将为大家详细讲解有关批处理如何实现延迟执行命令,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。2003的工具包里有个sleep.exe2、结合vbs实现的代码代码如下:echo.wscript.sl...
    99+
    2023-06-09
  • 如何在Hive中执行复杂查询和子查询
    在Hive中执行复杂查询和子查询可以通过使用HiveQL语言来实现。HiveQL语言类似于SQL,可以用于编写复杂的查询语句。 以下...
    99+
    2024-03-12
    Hive
  • MySql子查询IN的执行和优化的实现
    目录IN为什么慢?IN和EXISTS哪个快?如何提高效率?MySQL5.6对子查询的优化?SEMI JOIN策略Duplicate Weedout优化Materialization优...
    99+
    2024-04-02
  • 如何在MySQL中执行子查询
    在MySQL中执行子查询可以通过将子查询语句包含在主查询语句中的方式来实现。以下是一个简单的例子: SELECT colum...
    99+
    2024-03-06
    MySQL
  • LINQ to DataSet如何实现查询
    这篇文章主要介绍了LINQ to DataSet如何实现查询,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。LINQ to DataSet主要是提供对离线数据的支持,只有在填充...
    99+
    2023-06-17
  • LINQ如何实现查询操作
    这篇文章主要介绍了LINQ如何实现查询操作,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。LINQ,语言级集成查询(Language INtegrated Query)经过了最...
    99+
    2023-06-17
  • 如何实现LINQ查询语句
    本篇文章给大家分享的是有关如何实现LINQ查询语句,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。实现LINQ查询语句有三个步骤,他们分别是获取数据源(任何查询的必备工作)、创建...
    99+
    2023-06-17
  • MySql子查询IN的执行和优化的实现方法
    这篇文章主要讲解了“MySql子查询IN的执行和优化的实现方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySql子查询IN的执行和优化的实现方法”吧!目录IN为什么慢?IN和EXIST...
    99+
    2023-06-20
  • LINQ如何实现查询表达式
    这篇文章主要介绍了LINQ如何实现查询表达式,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。新建一个叫Step1.aspx的新页面。添加一个GridView控件到页面中,如下所...
    99+
    2023-06-17
  • SQL如何实现子查询
    这篇文章主要为大家展示了“SQL如何实现子查询”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“SQL如何实现子查询”这篇文章吧。 1...
    99+
    2024-04-02
  • 如何查询mysql正在执行的进程
    下面讲讲关于如何查询mysql正在执行的进程,文字的奥妙在于贴近主题相关。所以,闲话就不谈了,我们直接看下文吧,相信看完如何查询mysql正在执行的进程这篇文章你一定会有所受益。查看mysql进程有两种方法...
    99+
    2024-04-02
  • SSH如何实现条件查询和分页查询
    这篇文章将为大家详细讲解有关SSH如何实现条件查询和分页查询,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1、QueryHelper和PageResultQueryHel...
    99+
    2024-04-02
  • 如何理解MySQL的查询执行计划和优化器?
    如何理解MySQL的查询执行计划和优化器?概述:MySQL是最常用的开源关系型数据库之一,其查询执行计划和优化器是MySQL查询性能优化的关键。了解和理解MySQL的查询执行计划和优化器可以帮助我们优化查询语句,提高数据库的性能。本文将介绍...
    99+
    2023-10-22
    MySQL查询 执行计划 优化器
  • 在AmazonAurora中如何优化查询性能和执行计划
    要在Amazon Aurora中优化查询性能和执行计划,可以尝试以下一些方法: 使用合适的索引:确保在数据库表中使用适当的索引来...
    99+
    2024-04-02
  • Teradata的查询优化器和执行引擎是如何提升查询性能的
    Teradata的查询优化器和执行引擎通过以下方式提升查询性能: 查询优化器会根据查询语句的特性和表结构等信息,生成最优的查询计...
    99+
    2024-04-09
    Teradata
  • 如何在SQL Server数据库中实现子查询
    本篇文章给大家分享的是有关如何在SQL Server数据库中实现子查询,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1 子查询子查询是一个嵌套在select、insert、up...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作