189 8069 5689

LINQ查询表达式中如何实现复合from子句

这篇文章主要为大家展示了“LINQ查询表达式中如何实现复合from子句”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“LINQ查询表达式中如何实现复合from子句”这篇文章吧。

让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:域名申请网站空间、营销软件、网站建设、莱州网站维护、网站推广。

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

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查询运行结果快照。

LINQ查询表达式中如何实现复合from子句

以上是“LINQ查询表达式中如何实现复合from子句”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!


文章题目:LINQ查询表达式中如何实现复合from子句
当前路径:http://cdxtjz.cn/article/gepgge.html

其他资讯