当前位置:主页   - 电脑 - 网站开发 - ASP.Net
LINQ查询表达式中的复合from子句
来源:网络   作者:   更新时间:2012-08-04
收藏此页】    【字号    】    【打印】    【关闭

  1.     功能

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

  2.     语法要求

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

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

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

  ④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服务器标签控件中。

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查询表达式中的复合from子句

其它资源
来源声明

版权与免责声明
1、本站所发布的文章仅供技术交流参考,本站不主张将其做为决策的依据,浏览者可自愿选择采信与否,本站不对因采信这些信息所产生的任何问题负责。
2、本站部分文章来源于网络,其版权为原权利人所有。由于来源之故,有的文章未能获得作者姓名,署“未知”或“佚名”。对于这些文章,有知悉作者姓名的请告知本站,以便及时署名。如果作者要求删除,我们将予以删除。除此之外本站不再承担其它责任。
3、本站部分文章来源于本站原创,本站拥有所有权利。
4、如对本站发布的信息有异议,请联系我们,经本站确认后,将在三个工作日内做出修改或删除处理。
请参阅权责声明