日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關咨詢
選擇下列產(chǎn)品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
LINQ查詢表達式中的復合from子句

1.     功能

創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供豐南網(wǎng)站建設、豐南做網(wǎng)站、豐南網(wǎng)站設計、豐南網(wǎng)站制作等企業(yè)網(wǎng)站建設、網(wǎng)頁設計與制作、豐南企業(yè)網(wǎng)站模板建站服務,10多年豐南做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡服務。

from子句負責指定LINQ查詢操作中的數(shù)據(jù)源和范圍變量。

2.     語法要求

①每一個LINQ查詢表達式都必須包含from子句,且必須以from子句開頭。

②如果LINQ查詢表達式還包含子查詢,那么子查詢表達式也必須以from子句開頭。

③數(shù)據(jù)源不但包括LINQ查詢本身的數(shù)據(jù)源,而且還包括子查詢的數(shù)據(jù)源。范圍變量一般用來表示源序列中的每一個元素。

④from子句指定的數(shù)據(jù)源的類型必須為IEnumerable、IEnumerable 或前兩者的派生類型。

⑤在from子句中,如果數(shù)據(jù)源實現(xiàn)了IEnumerable ,那么編譯器可以自動推斷出范圍變量的類型。然而,如果數(shù)據(jù)源的類型是非泛型IEnumerable類型(如ArrayList等)時,則必須顯式指定范圍變量的數(shù)據(jù)類型。

3.    

復合from子句查詢舉例

在有些情況下,數(shù)據(jù)源的每一個元素本身可能還包含另一個子數(shù)據(jù)源(如序列、列表等)。此時,如果要查詢子數(shù)據(jù)源中的元素,則需要使用復合類型的from子句。

下面的實例演示了復合from子句查詢的方法,具體步驟說明如下。

(1)創(chuàng)建數(shù)據(jù)類型為List 的數(shù)據(jù)源。其中,students元素的Scores屬性的數(shù)據(jù)類型是List ,即該屬性的值也是一個子數(shù)據(jù)源。

(2)使用復合from子句查詢每個學生的各個大于90分的科目成績信息。第1個from子句負責查詢students數(shù)據(jù)源,第2個from子句則用于查詢student.Scores數(shù)據(jù)源。

(3)使用foreach語句輸出查詢的結果,并把此結果最終顯示于ASP.NET服務器標簽控件中。

 
 
 
 
  1. public class Student   
  2. {   
  3.    public string LastName { get; set; }   
  4.    public List Scores { get; set; }   
  5. }   
  6. ……(省略)   
  7. StringBuilder str = new StringBuilder("");   
  8. //建立數(shù)據(jù)源   
  9. List students = new List   
  10.    {   
  11.       new Student {LastName="Omelchenko", Scores= new List {97, 97, 81, 60}},  
  12.       new Student {LastName="O'Donnell", Scores= new List {75, 80, 91, 39}},  
  13.       new Student {LastName="Mortensen", Scores= new List {88, 94, 65, 85}},  
  14.       new Student {LastName="Garcia", Scores= new List {97, 89, 99, 82}},  
  15.       new Student {LastName="Beebe", Scores= new List {35, 94, 91, 70}}  
  16.    };   
  17. //使用復合from子句循環(huán)搜索出每個學生的各個大于90分的成績  
  18. var scoreQuery =  
  19.     from student in students 
  20.     from score in student.Scores  
  21.     where score > 90  
  22.     select new { Last = student.LastName, score };  
  23.  //顯示查詢結果   
  24. foreach (var v in scoreQuery)   
  25. {   
  26.    str.Append(v.Last +" "+v.score+ "  ");   
  27. }   
  28. Label1.Text = "";   
  29. Label1.Text = str.ToString(); 

下圖給出了上例的LINQ查詢運行結果快照。

【編輯推薦】

  1. 使用LINQ查詢泛型字典Dictionary
  2. 淺談LINQ to SQL集成數(shù)據(jù)庫語言優(yōu)劣
  3. 淺談如何在ASP.NET中了解LINQ語句性能
  4. 淺談LINQ如何插入刪除和更新數(shù)據(jù)庫記錄備注
  5. 使用LINQ查詢非泛型類型

網(wǎng)頁題目:LINQ查詢表達式中的復合from子句
文章網(wǎng)址:http://www.5511xx.com/article/cocohjo.html