1. 功能
创新互联专业为企业提供丰南网站建设、丰南做网站、丰南网站设计、丰南网站制作等企业网站建设、网页设计与制作、丰南企业网站模板建站服务,10多年丰南做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。
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子句
URL地址:http://www.gawzjz.com/qtweb/news21/162621.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联