LINQ查詢表達式深入剖析
在向大家詳細介紹復(fù)合from子句查詢之前,首先讓大家了解下LINQ查詢表達式,然后全面介紹復(fù)合from子句查詢。
from子句負責指定LINQ查詢操作中的數(shù)據(jù)源和范圍變量
1.每一個LINQ查詢表達式都必須包含from子句,且必須以from子句開頭。
2.如果LINQ查詢表達式還包含子查詢,那么子查詢表達式也必須以from子句開頭。
3.數(shù)據(jù)源不但包括LINQ查詢本身的數(shù)據(jù)源,而且還包括子查詢的數(shù)據(jù)源。范圍變量一般用來表示源序列中的每一個元素。
4.from子句指定的數(shù)據(jù)源的類型必須為IEnumerable、IEnumerable或前兩者的派生類型。
5.在from子句中,如果數(shù)據(jù)源實現(xiàn)了IEnumerable,那么編譯器可以自動推斷出范圍變量的類型。然而,如果數(shù)據(jù)源的類型是非泛型IEnumerable類型(如ArrayList等)時,則必須顯式指定范圍變量的數(shù)據(jù)類型。
復(fù)合from子句查詢舉例
在有些情況下,數(shù)據(jù)源的每一個元素本身可能還包含另一個子數(shù)據(jù)源(如序列、列表等)。此時,如果要查詢子數(shù)據(jù)源中的元素,則需要使用復(fù)合類型的from子句。
下面的實例演示了復(fù)合from子句查詢的方法,具體步驟說明如下。
1.創(chuàng)建數(shù)據(jù)類型為List的數(shù)據(jù)源。其中,students元素的Scores屬性的數(shù)據(jù)類型是List,即該屬性的值也是一個子數(shù)據(jù)源。
2.使用復(fù)合from子句查詢每個學生的各個大于90分的科目成績信息。第1個from子句負責查詢students數(shù)據(jù)源,第2個from子句則用于查詢student.Scores數(shù)據(jù)源。
3.使用foreach語句輸出查詢的結(jié)果,并把此結(jié)果最終顯示于ASP.NET服務(wù)器標簽控件中。
- public class Student
- {
- public string LastName { get; set; }
- public List Scores { get; set; }
- }
- ……(省略)
- StringBuilder str = new StringBuilder("");
- //建立數(shù)據(jù)源
- 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}}
- };
- //使用復(fù)合from子句循環(huán)搜索出每個學生的各個大于90分的成績
- var scoreQuery =
- from student in students
- from score in student.Scores
- where score > 90
- select new { Last = student.LastName, score };
- //顯示查詢結(jié)果
- foreach (var v in scoreQuery)
- {
- str.Append(v.Last +" "+v.score+ "");
- }
- Label1.Text = "";
- Label1.Text = str.ToString();
【編輯推薦】