LINQ查询表达式深入剖析
在向大家详细介绍复合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数据源。