成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

LINQ查詢表達式中的復合from子句

開發 后端
本文來談談LINQ查詢表達式中的from子句。from子句指定SELECT語句查詢及與查詢相關的表或視圖。在FROM子句中最多可指定256個表或視圖,它們之間用逗號分隔。

<!--[if !supportLists]-->1.     <!--[endif]-->功能

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

<!--[if !supportLists]-->2.     <!--[endif]-->語法要求

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

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

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

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

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

<!--[if !supportLists]-->3.     <!--[endif]-->

復合from子句查詢舉例

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

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

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

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

(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. //建立數據源   
  9. List students = new List   
  10.    {   
  11.       new Student {LastName="Omelchenko"Scoresnew List {97, 97, 81, 60}},  
  12.       new Student {LastName="O'Donnell"Scoresnew List {75, 80, 91, 39}},  
  13.       new Student {LastName="Mortensen"Scoresnew List {88, 94, 65, 85}},  
  14.       new Student {LastName="Garcia"Scoresnew List {97, 89, 99, 82}},  
  15.       new Student {LastName="Beebe"Scoresnew List {35, 94, 91, 70}}  
  16.    };   
  17. //使用復合from子句循環搜索出每個學生的各個大于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集成數據庫語言優劣
  3. 淺談如何在ASP.NET中了解LINQ語句性能
  4. 淺談LINQ如何插入刪除和更新數據庫記錄備注
  5. 使用LINQ查詢非泛型類型
責任編輯:彭凡 來源: itpub
相關推薦

2009-08-27 13:10:54

LINQ from子句

2011-10-28 16:34:13

LINQ

2009-09-10 15:35:07

LINQ查詢表達式

2009-09-17 11:08:55

LINQ查詢表達式

2009-09-07 17:18:33

LINQ查詢表達式

2009-09-11 09:53:16

Linq查詢表達式

2009-08-27 09:13:28

LINQ查詢表達式

2009-09-17 09:09:50

Lambda表達式Linq查詢

2009-09-09 17:45:07

Linq表達式

2009-09-11 09:48:27

Linq Lambda

2009-09-17 14:21:19

LINQ表達式

2009-09-09 13:01:33

LINQ Lambda

2009-09-11 12:32:33

LINQ表達式

2009-09-15 15:18:00

Linq Lambda

2009-03-23 10:47:43

數據庫SQLLINQ

2009-09-17 09:15:49

Linq表達式樹

2009-09-15 17:30:00

Linq Lambda

2009-09-17 09:44:54

Linq Lambda

2009-09-17 10:40:22

Linq Lambda

2009-09-16 13:02:12

LINQ查詢子句
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品久久久久久吹潮 | 国产亚洲一区二区精品 | 国产综合精品 | 成人一区二区在线 | 天天干天天爱天天操 | 影音先锋欧美资源 | 不卡视频一区二区三区 | 欧美精品网 | 精品麻豆剧传媒av国产九九九 | 请别相信他免费喜剧电影在线观看 | 亚洲精品二区 | 亚洲国产一区二区三区在线观看 | 亚洲精品久久久久中文字幕欢迎你 | 一区二区三区视频在线观看 | 色婷婷一区 | 亚洲一区在线播放 | 亚洲 欧美 日韩 在线 | 天天综合亚洲 | 久久久久亚洲精品 | 亚洲国产精品suv | 日韩av一二三区 | 亚洲一区二区免费视频 | 欧美色综合一区二区三区 | 欧美jizzhd精品欧美巨大免费 | 久久久激情 | 亚洲精品一区二区 | 国产高清在线精品一区二区三区 | 男女视频免费 | 巨大黑人极品videos精品 | 国产精品久久久久久久久久久免费看 | 99亚洲精品| 夜夜夜久久久 | av在线天天 | 久久99精品视频 | 久久久成人一区二区免费影院 | 91精品免费 | 欧美成年黄网站色视频 | 日韩成人免费av | 国产黄色在线观看 | 亚洲一区精品在线 | 国产精品免费一区二区三区四区 |