LINQ查询表达式深入剖析

开发 后端
这里介绍LINQ查询表达式,以及介绍使用复合from子句查询每个学生的各个大于90分的科目成绩信息。第1个from子句负责查询students数据源,第2个from子句则用于查询student.Scores数据源。

在向大家详细介绍复合from子句查询之前,首先让大家了解下LINQ查询表达式,然后全面介绍复合from子句查询。

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

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

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

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

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

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

复合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"Scoresnew List {97, 97, 81, 60}},  
  12. new Student {LastName="O'Donnell"Scoresnew List {75, 80, 91, 39}},  
  13. new Student {LastName="Mortensen"Scoresnew List {88, 94, 65, 85}},  
  14. new Student {LastName="Garcia"Scoresnew List {97, 89, 99, 82}},  
  15. new Student {LastName="Beebe"Scoresnew 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(); 

【编辑推荐】

  1. LINQ to SQL数据表介绍
  2. LINQ查询的目的与实现手段
  3. LINQ from子句进行复合查询实现方法
  4. LINQ查询表达式功能详解
  5. LINQ基础概念总结
责任编辑:佚名 来源: IT168
相关推荐

2009-09-10 15:35:07

LINQ查询表达式

2009-09-11 09:48:27

Linq Lambda

2009-09-17 14:21:19

LINQ表达式

2011-10-28 16:34:13

LINQ

2009-09-11 09:53:16

Linq查询表达式

2009-08-27 09:13:28

LINQ查询表达式

2009-09-17 14:24:35

LINQ表达式

2009-09-17 11:08:55

LINQ查询表达式

2009-09-17 09:09:50

Lambda表达式Linq查询

2009-09-11 12:32:33

LINQ表达式

2009-09-15 15:18:00

Linq Lambda

2009-09-09 13:01:33

LINQ Lambda

2009-09-09 17:45:07

Linq表达式

2009-06-12 09:44:04

LINQ查询复合from子句

2009-09-17 10:40:22

Linq Lambda

2009-09-15 17:30:00

Linq Lambda

2009-09-17 09:44:54

Linq Lambda

2009-09-17 09:15:49

Linq表达式树

2009-03-23 10:47:43

数据库SQLLINQ

2009-09-09 17:14:17

Linq lambda
点赞
收藏

51CTO技术栈公众号