真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

LINQ入門知識點有哪些

本篇內(nèi)容主要講解“LINQ入門知識點有哪些”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“LINQ入門知識點有哪些”吧!

成都創(chuàng)新互聯(lián)專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于網(wǎng)站建設(shè)、成都網(wǎng)站建設(shè)、東坡網(wǎng)絡(luò)推廣、微信平臺小程序開發(fā)、東坡網(wǎng)絡(luò)營銷、東坡企業(yè)策劃、東坡品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們最大的嘉獎;成都創(chuàng)新互聯(lián)為所有大學(xué)生創(chuàng)業(yè)者提供東坡建站搭建服務(wù),24小時服務(wù)熱線:18980820575,官方網(wǎng)址:www.cdcxhl.com

簡 介

LINQ 是什么?引用官方術(shù)語“語言集成查詢 (LINQ) 是 Visual Studio 2008 和 .NET work 3.5 版中引入的一項創(chuàng)新功能,它在對象領(lǐng)域和數(shù)據(jù)領(lǐng)域之間架起了一座橋梁。” 那么LINQ給我們帶來了什么,請看以下例子:

問:有序列A=int[]{1,2,3,4,5,6,7,8,0}; B=int[]{2,4,7,8,9}。請求出包含A和B共同值的序列C。

如果按照原來的思路,那么編碼也許如下:

說明:

List c = new List();foreach(int a in A){  foreach(int b in b) {    if (a==b) {      c.add(a);    }  }}

說明:

是不是覺得上面這段雖然沒什么問題,但是很丑陋。如果我們引用LINQ來編寫呢:

IEnumerable C = from a in A           from b in B           where a==b           select a;

語 法

1. LINQ所處在的主要命名空間:System.Linq

2. LINQ的處理的核心對象就是IEnumerable可枚舉對象也包括了泛型枚舉,換句話說當(dāng)你要處理的對象為IEnumerable類型對象時即可使用LINQ操作它。且在沒有經(jīng)過其他處理的情況下將返回一個新的IEnumerable序列,注意LINQ有一個特性“延遲加載”這個將在后續(xù)說明。

3. 關(guān)鍵字(摘自MSDN):

from : 指定數(shù)據(jù)源和范圍變量(類似于迭代變量)。

where: 根據(jù)一個或多個由邏輯“與”和邏輯“或”運(yùn)算符(&& 或 ||)分隔的布爾表達(dá)式篩選源元素。

select: 指定當(dāng)執(zhí)行查詢時返回的序列中的元素將具有的類型和形式。

group: 按照指定的鍵值對查詢結(jié)果進(jìn)行分組。

into: 提供一個標(biāo)識符,它可以充當(dāng)對 join、group 或 select 子句的結(jié)果的引用。

orderby: 基于元素類型的默認(rèn)比較器按升序或降序?qū)Σ樵兘Y(jié)果進(jìn)行排序。

join: 基于兩個指定匹配條件之間的相等比較來聯(lián)接兩個數(shù)據(jù)源。

let: 引入一個用于存儲查詢表達(dá)式中的子表達(dá)式結(jié)果的范圍變量。

in: join 子句中的上下文關(guān)鍵字。

on: join 子句中的上下文關(guān)鍵字。

equals: join 子句中的上下文關(guān)鍵字。

by: group 子句中的上下文關(guān)鍵字。

ascending:orderby 子句中的上下文關(guān)鍵字。

descending:orderby 子句中的上下文關(guān)鍵字。

4. 語法說明,每個LINQ語句都以from作為開頭,以select作為結(jié)束,這點和T-SQL語法不通的切記先入為主的思考。其他關(guān)鍵字如where則類似T-SQL作為篩選判斷條件。

樣例:IEnumerable nums = from n in nums where .... orderby... select....

擴(kuò) 展

從 .net 3.0 開始 MS 就給我們引進(jìn)了其他一些新的特性,由于篇幅關(guān)系在這里給大家簡單的介紹幾個LINQ常用到的特性:

1. 關(guān)鍵字 var :

指示編譯器根據(jù)初始化語句右側(cè)的表達(dá)式推斷變量的類型。 推斷類型可以是內(nèi)置類型、匿名類型、用戶定義類型或 .NET Framework 類庫中定義的類型。這樣我們就可以在上述的LINQ表達(dá)式中 例如可簡寫為: var nums = from n in nums where .... orderby... select....

2. 匿名類型:

匿名類型提供了一種方便的方法,可用來將一組只讀屬性封裝到單個對象中,而無需首先顯式定義一個類型。 類型名由編譯器生成,并且不能在源代碼級使用。 每個屬性的類型由編譯器推斷。例如:var obj = new {A="a", B="b"}; 而LINQ則可以為 var nums = from obj in objs select new {obj.A, obj.B}

案 例

普通查詢

var query = from num in num       select num.ProperyA

篩選查詢

var query = from obj in objs      where obj.ProperyA > Condition      select obj

分組查詢

var query = from obj in objs      group obj by obj.PropertyA into g      orderby g.Key      select g;

注意,在此示例里,關(guān)鍵字 into 不是必須的,使用 into 時,必須繼續(xù)編寫該查詢,并最終用一個 select 語句或另一個 group 子句結(jié)束該查詢。

內(nèi)聯(lián)查詢

var query= from obj1 in objs1      join obj2 in objs2 on obj1.ID equals obj2.ID      select new { A= obj1.Property, B = obj2.Property };

左外聯(lián)查詢

var query = from obj1 in objs1      join obj2 in objs2 on obj1.ID equals obj2.Obj1ID into g      from subpet in g.DefaultIfEmpty()      select new { P1 = obj1.P1, P2 = (subpet == null ? null : subpet.P2 ) };

注意,此處涉及到.net 3.5 新特性靜態(tài)擴(kuò)展方法(后續(xù)介紹不影響理解)DefaultIfEmpty():如果序列為空,則返回一個具有默認(rèn)值的單一實例集合

到此,相信大家對“LINQ入門知識點有哪些”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!


分享題目:LINQ入門知識點有哪些
URL分享:http://weahome.cn/article/johdii.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部