LINQ查询表达式中的复合from子句
创始人
2024-04-01 19:31:15
0

1.     功能

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

2.     语法要求

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

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

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

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

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

3.    

复合from子句查询举例

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

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

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

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

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

  1. public class Student   
  2. {   
  3.    public string LastName { get; set; }   
  4.    public List Scores { get; set; }   
  5. }   
  6. ……(省略)   
  7. StringBuilder str = new StringBuilder("");   
  8. //建立数据源   
  9. List students = new List   
  10.    {   
  11.       new Student {LastName="Omelchenko", Scores= new List {97, 97, 81, 60}},  
  12.       new Student {LastName="O'Donnell", Scores= new List {75, 80, 91, 39}},  
  13.       new Student {LastName="Mortensen", Scores= new List {88, 94, 65, 85}},  
  14.       new Student {LastName="Garcia", Scores= new List {97, 89, 99, 82}},  
  15.       new Student {LastName="Beebe", Scores= new List {35, 94, 91, 70}}  
  16.    };   
  17. //使用复合from子句循环搜索出每个学生的各个大于90分的成绩  
  18. var scoreQuery =  
  19.     from student in students 
  20.     from score in student.Scores  
  21.     where score > 90  
  22.     select new { Last = student.LastName, score };  
  23.  //显示查询结果   
  24. foreach (var v in scoreQuery)   
  25. {   
  26.    str.Append(v.Last +" "+v.score+ "  ");   
  27. }   
  28. Label1.Text = "";   
  29. Label1.Text = str.ToString(); 

下图给出了上例的LINQ查询运行结果快照。

查询结果快照

【编辑推荐】

  1. 使用LINQ查询泛型字典Dictionary
  2. 浅谈LINQ to SQL集成数据库语言优劣
  3. 浅谈如何在ASP.NET中了解LINQ语句性能
  4. 浅谈LINQ如何插入删除和更新数据库记录备注
  5. 使用LINQ查询非泛型类型

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...