天天躁日日躁狠狠躁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)系我們修改或刪除,多謝。

主站蜘蛛池模板: 一二三区乱码不卡手机版 | 精品国产影院 | caoporn 免费视频 | 久久久精品日本一区二区三区 | se01短视频在线观看 | 亚洲高清视频在线观看 | 极品美女久久久久久久久久久 | 国产精品美女久久久久浪潮AV | xx在线观看| 国产精品亚洲专区在线播放 | 暖暖 免费 高清 日本视频大全 | 国产精亚洲视频综合区 | 天天操狠狠操夜夜操 | 精品久久久久久久国产潘金莲 | 亚洲综合中文字幕无线码 | 日韩精品卡1卡2三卡四卡乱码 | 中国特级黄色大片 | 色老板美国在线观看 | 日本三区四区免费高清不卡 | 亚洲成在人线视频 | 久久久综合中文字幕久久 | 秋霞电影网伦大理电影在线观看 | 特级毛片AAAAAA | 伊人久久大香线蕉影院95 | 美女被打开了屁股进去的视频 | 99久久久精品免费观看国产 | 欧美ⅹxxxx18性欧美 | 人人干人人看 | 野花香在线观看免费高清播放视频 | 亚洲伊人久久综合影院2021 | 日韩成人性视频 | 好大好爽CAO死我了BL | a视频在线观看 | 草莓国产视频免费观看 | 中文字幕亚洲欧美日韩2019 | 亚洲精品福利在线 | 最近中文字幕免费高清MV视频 | 亲胸揉胸膜下刺激视频在线观看 | 亚洲 日韩 国产 制服 在线 | 性刺激欧美三级在线现看中文 | 九九久久国产精品大片 |