文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2023-06-17 22:12

关注

这篇文章将为大家详细讲解有关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如何实现子查询和延迟执行编程”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯