天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

LINQ 查詢介紹

查詢是一種從數(shù)據(jù)源檢索數(shù)據(jù)的表達式。查詢通常用專門的查詢語言來表示。隨著時間的推移,人們已經為各種數(shù)據(jù)源開發(fā)了不同的語言;例如,用于關系數(shù)據(jù)庫的 SQL 和用于 XML 的 XQuery。因此,開發(fā)人員不得不針對他們必須支持的每種數(shù)據(jù)源或數(shù)據(jù)格式而學習新的查詢語言。LINQ 通過提供一種跨各種數(shù)據(jù)源和數(shù)據(jù)格式使用數(shù)據(jù)的一致模型,簡化了這一情況。在 LINQ 查詢中,始終會用到對象。可以使用相同的基本編碼模式來查詢和轉換 XML 文檔、SQL 數(shù)據(jù)庫、ADO.NET 數(shù)據(jù)集、.NET 集合中的數(shù)據(jù)以及對其有 LINQ 提供程序可用的任何其他格式的數(shù)據(jù)。

查詢操作的三個部分

所有 LINQ 查詢操作都由以下三個不同的操作組成:

  • 獲取數(shù)據(jù)源。
  • 創(chuàng)建查詢。
  • 執(zhí)行查詢。

下面的示例演示如何用源代碼表示查詢操作的三個部分。為了方便起見,此示例將一個整數(shù)數(shù)組用作數(shù)據(jù)源;但其中涉及的概念同樣適用于其他數(shù)據(jù)源。本主題的其余部分也會引用此示例。

class IntroToLINQ
{
static void Main()
{
// The Three Parts of a LINQ Query:
// 1. Data source.
int[] numbers = new int[7] { 0, 1, 2, 3, 4, 5, 6 };

// 2. Query creation.
// numQuery is an IEnumerable<int>
var numQuery =
from num
in numbers
where (num % 2) == 0
select num;

// 3. Query execution.
foreach (int num in numQuery)
{
Console.Write(
"{0,1} ", num);
}
}
}

下圖顯示了完整的查詢操作。在 LINQ 中,查詢的執(zhí)行與查詢本身截然不同;換句話說,如果只是創(chuàng)建查詢變量,則不會檢索任何數(shù)據(jù)。

數(shù)據(jù)源

在上一個示例中,由于數(shù)據(jù)源是數(shù)組,因此它隱式支持泛型 IEnumerable<(Of <(T>)>) 接口。這一事實意味著該數(shù)據(jù)源可以用 LINQ 進行查詢。在 foreach 語句中執(zhí)行查詢,而 foreach 要求使用 IEnumerable 或 IEnumerable<(Of <(T>)>)。支持 IEnumerable<(Of <(T>)>) 或派生接口(如泛型 IQueryable<(Of <(T>)>))的類型稱為“可查詢類型”。

可查詢類型不需要進行修改或特殊處理就可以用作 LINQ 數(shù)據(jù)源。如果源數(shù)據(jù)還沒有作為可查詢類型出現(xiàn)在內存中,則 LINQ 提供程序必須以此方式表示源數(shù)據(jù)。例如,LINQ to XML 將 XML 文檔加載到可查詢的 XElement 類型中:

 

// Create a data source from an XML document.
// using System.Xml.Linq;
XElement contacts = XElement.Load(@"c:/myContactList.xml");

 

查詢

查詢指定要從數(shù)據(jù)源中檢索的信息。查詢還可以指定在返回這些信息之前如何對其進行排序、分組和結構化。查詢存儲在查詢變量中,并用查詢表達式進行初始化。為使編寫查詢的工作變得更加容易,C# 引入了新的查詢語法。

上一個示例中的查詢從整數(shù)數(shù)組中返回所有偶數(shù)。該查詢表達式包含三個子句:from、where 和 select。(如果您熟悉 SQL,您會注意到這些子句的順序與 SQL 中的順序相反。) from 子句指定數(shù)據(jù)源,where 子句應用篩選器,select 子句指定返回的元素的類型。LINQ 查詢表達式(C# 編程指南)一節(jié)中詳細討論了這些子句和其他查詢子句。目前需要注意的是,在 LINQ 中,查詢變量本身不執(zhí)行任何操作并且不返回任何數(shù)據(jù)。它只是存儲在以后某個時刻執(zhí)行查詢時為生成結果而必需的信息。有關在幕后是如何構建查詢的更多信息,請參見標準查詢運算符概述。

查詢執(zhí)行

延遲執(zhí)行

如前所述,查詢變量本身只是存儲查詢命令。實際的查詢執(zhí)行會延遲到在 foreach 語句中循環(huán)訪問查詢變量時發(fā)生。此概念稱為“延遲執(zhí)行”,下面的示例對此進行了演示:

 

//  Query execution. 
foreach (int num in numQuery)
{
Console.Write(
"{0,1} ", num);
}

it知識庫LINQ 查詢介紹,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 伊人久久综合影院首页 | 99热在线视频这里只精品 | 国产亚洲精品在线视频 | 日本熟妇乱妇熟色A片蜜桃 日本熟妇多毛XXXXX视频 | 快穿之H啪肉 | 秋霞电影在线观看午夜伦 | 国产精品一区二区亚瑟不卡 | 国产精品视频在线自在线 | 男女肉大捧进出全过程免费 | 中国成人在线视频 | 中国国产不卡视频在线观看 | 日韩欧美中文字幕一区 | 乌克兰粉嫩摘花第一次 | 99久久蜜臀亚洲AV无码精品 | 欧美高清 videos sexo | 精品欧美一区二区三区久久久 | 亚洲人成77777| Zoofilivideo人馿交 | 91亚洲精品福利在线播放 | 欧美色图一区二区三区 | 亚洲精品乱码8久久久久久日本 | 无码国产精品高潮久久9 | 十分钟视频影院免费 | 成人免费在线 | 成人免费小视频 | 97人妻久久久精品系列A片 | 国产精品久久久久久52AVAV | 亚洲精品无码AV中文字幕蜜桃 | 亚洲熟女片嫩草影院 | ZZoo兽2皇| 精品人妻伦一二三区久久AAA片 | 97欧美精品大香伊蕉在人线 | 成人在免费视频手机观看网站 | 人妻互换免费中文字幕 | 欧美高清videossexo | 2019在秋霞理论| 国产精品嫩草久久久久 | 成人高清护士在线播放 | 亚洲日本欧美国产在线视 | 亚洲国产三级在线观看 | 久久免费精品国产72精品剧情 |