溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

LINQ如何實現(xiàn)子查詢和延遲執(zhí)行編程

發(fā)布時間:2021-12-02 09:20:34 來源:億速云 閱讀:372 作者:小新 欄目:編程語言

這篇文章將為大家詳細(xì)講解有關(guān)LINQ如何實現(xiàn)子查詢和延遲執(zhí)行編程,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

LINQ子查詢

LINQ子查詢是一個包含了另外一個查詢的Lambda表達(dá)式的查詢. 以下的例子使用了一個LINQ子查詢來針對籃球明星的last name排序:

string[] players = { "Tim Ducan", "Lebrom James", "Kobe Byrant" };   IEnumerable<string> q = players.OrderBy (m => m.Split().Last());

在這其中, Last是一個LINQ子查詢, q則代表了一個外部查詢.

在LINQ子查詢中, 你可以在Lambda表達(dá)式的右邊使用任何可行的C#表達(dá)語法.LINQ 子查詢只是一個簡單的C#表達(dá)式, 這意味著所有適用于LINQ子查詢的規(guī)則都可以推導(dǎo)到Lambda表達(dá)式上.

以下的查詢?nèi)〉靡粋€字符數(shù)組中所有滿足長度等于最小長度的字符序列:

string[] names = { "James","Jack","Landy","C.Y","Jay" };     IEnumerable<string> q = names       .Where (n => n.Length ==          names.OrderBy (n2 => n2.Length)               .Select  (n2 => n2.Length).First( )       );     foreach(var s in q)     {         Console.WriteLine(s); //C.Y , Jay    }

對于LINQ子查詢, 可以引用到外部的Lambda參數(shù)或者是迭代變量(在復(fù)合查詢中). 例如上述的例子中, 如果OrderBy使用的表達(dá)式改為(n => n.Length)而不是用n2的話將會得到一個錯誤信息:

A local variable named ‘n’ cannot be declared in this scope because it would give a different meaning to ‘n’, which is already used in a ‘parent or current’ scope to denote something else.

針對這個例子, 我們可以看到對應(yīng)的復(fù)合查詢寫法:

IEnumerable<string> q =       from n in names       where n.Length ==         (from n2 in names          orderby n2.Length          select n2.Length).First( )       select n;

外部迭代變量n在LINQ子查詢范圍內(nèi)是可見的, 因此我們不能將它重用為LINQ子查詢內(nèi)部的迭代變量.

LINQ子查詢會在對應(yīng)的Lambda表達(dá)式被執(zhí)行的時候來執(zhí)行, 其執(zhí)行取決于外部查詢, 也可以說是由外到里來處理的. 本地查詢完全遵循這個模型, 但是解釋型查詢(例如LINQ to SQL)則僅僅是概念上遵循而已.

之前的查詢我們還可以使用一種更加簡潔的寫法:

IEnumerable<string> q =       from n in names       where  n.Length ==              names.OrderBy (n2 => n2.Length).First().Length       select n;

如果使用Min聚合函數(shù), 還可以進(jìn)一步簡化:

IEnumerable<string> q =           from n in names           where n.Length == names.Min (n2 => n2.Length)           select n;

實際上, 由于n2.Length在外部查詢循環(huán)的時候每次都會重新計算, 這在某些情況下可能會引起效率問題, 避免這個問題, 我們可以將LINQ子查詢分離出來:

int len = names.Min (n => n.Length);           IEnumerable<string> query = from   n in names                                 where  n.Length == len                                 select n;

子查詢和延遲執(zhí)行

在LINQ子查詢中的返回單一元素或者聚合類操作符, 例如first或者Count, 并不會強(qiáng)制外部查詢立即執(zhí)行, 也就說外部查詢依然擁有延遲執(zhí)行的能力. 這是因為LINQ子查詢是被間接調(diào)用的 – 如果是本地查詢則是通過代理(delegate), 如果是解釋性查詢則是通過表達(dá)樹(expression tree).

一個有趣的現(xiàn)象是當(dāng)你的LINQ子查詢中包含一個Select表達(dá)式的時候, 如果是本地查詢, 你實際上是將其發(fā)散成一序列的查詢 – 并且每一個都擁有延遲執(zhí)行的能力. 這個影響是透明的, 因為它可以顯著提高效率.

關(guān)于“LINQ如何實現(xiàn)子查詢和延遲執(zhí)行編程”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI