文章详情

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

请输入下面的图形验证码

提交验证

短信预约提醒成功

LINQ查询表达式怎么用

2023-06-17 22:25

关注

这篇文章主要介绍了LINQ查询表达式怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

from子句负责指定LINQ查询操作中的数据源和范围变量

每一个LINQ查询表达式都必须包含from子句,且必须以from子句开头。

如果LINQ查询表达式还包含子查询,那么子查询表达式也必须以from子句开头。

数据源不但包括LINQ查询本身的数据源,而且还包括子查询的数据源。范围变量一般用来表示源序列中的每一个元素。

from子句指定的数据源的类型必须为IEnumerable、IEnumerable或前两者的派生类型。

在from子句中,如果数据源实现了IEnumerable,那么编译器可以自动推断出范围变量的类型。然而,如果数据源的类型是非泛型IEnumerable类型(如ArrayList等)时,则必须显式指定范围变量的数据类型。

复合from子句查询举例

在有些情况下,数据源的每一个元素本身可能还包含另一个子数据源(如序列、列表等)。此时,如果要查询子数据源中的元素,则需要使用复合类型的from子句。

下面的实例演示了复合from子句查询的方法,具体步骤说明如下。

创建数据类型为List的数据源。其中,students元素的Scores属性的数据类型是List,即该属性的值也是一个子数据源。

使用复合from子句查询每个学生的各个大于90分的科目成绩信息。第1个from子句负责查询students数据源,第2个from子句则用于查询student.Scores数据源。

使用foreach语句输出查询的结果,并把此结果最终显示于ASP.NET服务器标签控件中。

public class Student   {   public string LastName { get; set; }   public List Scores { get; set; }   }   ……(省略)   StringBuilder str = new StringBuilder("");   //建立数据源   List students = new List   {   new Student {LastName="Omelchenko", Scores= new List {97, 97, 81, 60}},  new Student {LastName="O'Donnell", Scores= new List {75, 80, 91, 39}},  new Student {LastName="Mortensen", Scores= new List {88, 94, 65, 85}},  new Student {LastName="Garcia", Scores= new List {97, 89, 99, 82}},  new Student {LastName="Beebe", Scores= new List {35, 94, 91, 70}}  };   //使用复合from子句循环搜索出每个学生的各个大于90分的成绩  var scoreQuery =  from student in students   from score in student.Scores  where score > 90  select new { Last = student.LastName, score };  //显示查询结果   foreach (var v in scoreQuery)   {   str.Append(v.Last +" "+v.score+ "");   }   Label1.Text = "";   Label1.Text = str.ToString();

感谢你能够认真阅读完这篇文章,希望小编分享的“LINQ查询表达式怎么用”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!

阅读原文内容投诉

免责声明:

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

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

软考中级精品资料免费领

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

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

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

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

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

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

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