婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 新Orcas語言特性-查詢句法

新Orcas語言特性-查詢句法

熱門標簽:淮安自動外呼系統開發 百變地圖標注 語音電話機器人營銷方案 語音電話機器人缺點 廣州市400電話辦理 宜賓外呼系統廠家 地圖標注原件 修改高德地圖標注 南通防封外呼系統運營商

【原文地址】New "Orcas" Language Feature: Query Syntax
【原文發表日期】 Saturday, April 21, 2007 2:12

上個月我開始了一個貼子系列,討論作為Visual Studio和.NET框架Orcas版本一部分發布的一些新的VB和C#語言特性。下面是該系列的前三篇貼子的鏈接:

  • 自動屬性,對象初始化器,和集合初始化器
  • 擴展方法
  • Lambda表達式

今天的貼子要討論另一個基礎性的新語言特性:查詢句法(Query Syntax)

什么是查詢句法(Query Syntax)?

查詢句法是使用標準的LINQ查詢運算符來表達查詢時一個方便的聲明式簡化寫法。該句法能在代碼里表達查詢時增進可讀性和簡潔性,讀起來容易,也容易讓人寫對。Visual Studio 對查詢句法提供了完整的intellisense和編譯時檢查支持。

在底下,C#和VB編譯器則把查詢句法的表達式翻譯成明確的方法調用代碼,這樣的代碼利用了Orcas中的新的擴展方法和Lambda表達式語言特性。

查詢句法的例子:

在我以前的語言系列貼子里,我示范了你可以象下面這樣聲明一個Person類:

 

然后我們可以使用下面這樣的代碼,用一些個人信息來生成一個ListPerson>集合實例,然后使用查詢句法來對該集合做一個LINQ查詢,只取出那些姓(last name)的首字母為G的人,按名字(first name)來排序(升序):

上面查詢句法的表達式在語意上與下面明確使用LINQ擴展方法和Lambda表達式的代碼是等同的:

使用查詢句法方法的好處是,結果會是稍微容易讀寫些,這在表達式變得更繁復時尤其如此。

查詢句法 - 理解from和select子句:

在C#中,每個查詢表達式的句法從from子句開始,以select或group子句結束。from子句表示你要查詢什么數據。select子句則表示你要返回什么數據,且應該以什么構形返回。

譬如,讓我們再來看一下我們對ListPerson>集合的查詢:

在上面的代碼片段里,"from p in people"表示了我要對"people" 這個集合做一個LINQ查詢,我將用參數"p"代表我正查詢的輸入序列的每個項。我們將參數命名為"p" 這個事實是無關緊要的,我完全可以很容易地將其命名為"o", "x", "person"或我想要的任何名字。

在上面的代碼片段里,語句結尾的"select p"子句表示,作為查詢的結果,我要返回一個Person對象的IEnumerable序列。這是因為"people"集合包含了Person類型的對象,而參數p則代表了輸入序列中的Person對象。因此,該查詢句法表達式的結果數據類型是IEnumerablePerson>。

假如不是返回Person對象,我想返回該集合中的人的名字,我可以把查詢改寫成這樣:

注意上面我不再說"select p",而是說"select p.FirstName"。這表示我不想返回一串Person對象,而是想返回一串字符串,由Person對象的FirstName屬性(該屬性是個字符串)填充而來。 因此,該查詢句法表達式的結果類型是 IEnumerablestring>。

針對數據庫的查詢句法的例子

LINQ的妙處在于,我可以針對任何數據類型使用完全一樣的查詢句法。譬如,我可以使用Orcas提供的新LINQ到SQL對象關系映射器支持,對SQL服務器的Northwind數據庫進行建模,生成下面這些類(請觀看我這里的錄像來學習該如何實現):

在上面定義好類模型之后(以及它與數據庫間的映射關系),然后我就可以寫個查詢句法的表達式取出那些單價大于99元的產品:

在上面的代碼片段里,我表示我要對NorthwindDataContext類的Products表進行一個LINQ查詢,NorthwindDataContext類是由Visual Studio orcas的ORM設計器生成的。"select p"表示我要返回匹配我的查詢的一串Product對象,因此,該查詢句法表達式的結果數據類型是IEnumerableProduct>。

就象前面ListPerson>查詢句法的例子一樣,C# 編譯器會把我們的聲明式查詢句法翻譯成明確的擴展方法調用(使用Lambda表達式作為參數)。在上面的LINQ到SQL的例子的情形下,這些Lambda表達式會被轉化成SQL命令,然后在SQL服務器上做運算(這樣,只有那些匹配查詢條件的Product記錄行會返回到我們的應用中)。促成這個Lambda->SQL 轉化的機制的細節可見于我的Lambda表達式博客貼子的"Lambda表達式樹"部分。

查詢句法 - 理解where和orderby子句:

在一個查詢句法表達式開頭的"from" 子句和結尾的"select"子句之間,你可以使用最常見的LINQ查詢運算符來過濾和轉換你在查詢的數據。兩個最常用的子句是"where"和"orderby"。這兩個子句處理對結果集的過濾和排序。

譬如,要從Northwind數據庫里返回按字母降序排列的分類名稱列表,過濾條件是只包括那些含有5個以上產品的分類,我們可以編寫下面這樣的查詢句法來用LINQ到SQL對我們的數據庫做查詢:

在上面的表達式里,我們加了 "where c.Products.Count > 5" 子句來表示我們只要那些含有5個以上產品的分類。這利用了數據庫中產品和分類間的LINQ到SQL的ORM映射的關聯。在上面的表達式中,我也加了"order by c.CategoryName descending"子句來表示我要將結果集按名稱降序排列。

LINQ到SQL然后就會在使用這個表達式查詢數據庫時,生成下列SQL:

Select [t0].[CategoryName] FROM [dbo].[Categories] AS [t0]
Where ((
    Select COUNT(*)
    FROM [dbo].[Products] AS [t1]
    Where [t1].[CategoryID] = [t0].[CategoryID]
)) > 5
ORDER BY [t0].[CategoryName] DESC

注意,LINQ到SQL很聰明,只返回了我們所需的單個字段(分類名稱), 而且它是在數據庫層做了所有的過濾和排序,使得該查詢效率非常高。

查詢句法 - 用投影(Projection)來轉換數據

先前我指出的一個要點是,"select" 子句表示了你要返回的數據,以及這個數據的構形是什么

譬如,假如你有個象下面這樣的"select p" 子句,這里p的類型是Person,然后,它就會返回一串Person對象:

LINQ和查詢句法提供的一個非常強大的功能是允許你定義跟被查詢的數據分開的新的類型,然后用新的類型來控制查詢返回的數據的形狀和結構。

譬如,假設我們定義了一個新的AlternatePerson類,內含一個FullName屬性,而不是我們原先的Person類內的分開的FirstName和LastName屬性:

然后我就可以使用下面的LINQ查詢句法來查詢我原先的ListPerson>集合,用下面的查詢句法將結果轉換成一串AlternatePerson對象:

注意看,我們是如何在上面的表達式里的"select"子句里,使用我的語言系列的第一個貼子里討論過的新的對象初始化器句法來創建新的AlternatePerson實例,同時設置它的屬性的。也注意我是如何連接我們原先Person類的FirstName和LastName屬性,然后將其賦值給FullName屬性的。

對數據庫使用查詢句法投影

這個投影特性在操作從象數據庫這樣一個遠程數據提供器那里取回的數據時,會變得難以置信地有用,因為它提供給我們一個優雅的方式,來表示我們的ORM應該從數據庫實際取回哪些數據字段。

譬如,假設我用了LINQ到SQL的ORM提供器對Northwind數據庫建模,生成下面這些類:

通過編寫下面這個LINQ查詢,我告訴LINQ到SQL我要返回一串Product對象:

填充Product類所需的所有字段都將作為上面查詢的一部分從數據庫中返回,由LINQ到SQL orM執行的raw SQL看上去象下面這樣:

Select [t0].[ProductID], [t0].[ProductName], [t0].[SupplierID], [t0].[CategoryID],
              [t0].[QuantityPerUnit], [t0].[UnitPrice], [t0].[UnitsInStock],
              [t0].[UnitsOnOrder], [t0].[ReorderLevel], [t0].[Discontinued]
FROM [dbo].[Products] AS [t0]
Where [t0].[UnitPrice] > 99

在一些場景下,我不需要也不用所有這些字段,我可以定義一個下面這樣的新的MyProduct類,只擁有Product類具有的部分屬性,以及一個Product類并不具有的額外屬性,TotalRevenue (注: 對那些不熟悉C#的,Decimal?句法表示我們的UnitPrice屬性是個nullable值):

 

然后我就可以使用下面這個查詢,使用查詢句法的投影功能來構造我要從數據庫返回的數據的形狀:

這表明,不是返回一串Product對象,我要MyProduct對象,我只要其中三個屬性被賦值,LINQ到SQL就會很聰明地調整要執行的raw SQL語句,從數據庫只返回那三個需要的產品字段:

Select [t0].[ProductID], [t0].[ProductName], [t0].[UnitPrice]
FROM [dbo].[Products] AS [t0]
Where [t0].[UnitPrice] > 99

為炫耀起見,我也可以填充MyProduct類的第四個屬性,即TotalRevenue屬性。我要這個值等于我們產品目前的銷售額的總量。這個值在Northwind數據庫中并沒有作為一個預先算好的字段而存在。而是,你需要在Products表和Order Details表間做一個關聯,然后計算出一個給定產品對應的所有的Order Detail 行的總量。

非常酷的是,我可以在Product類的OrderDetails關聯上使用LINQ的 Sum 這個擴展方法,編寫一個作為我的查詢句法投影一部分的乘法Lambda表達式,來計算這個值:

LINQ到SQL就會非常聰明地使用下面這個SQL在SQL數據庫里做運算:

Select [t0].[ProductID], [t0].[ProductName], [t0].[UnitPrice], (
        Select SUM([t2].[value])
        FROM (
                 Select [t1].[UnitPrice] * (CONVERT(Decimal(29,4),[t1].[Quantity])) AS [value], [t1].[ProductID]
                 FROM [dbo].[Order Details] AS [t1]
                 ) AS [t2]
        Where [t2].[ProductID] = [t0].[ProductID]
        ) AS [value]
FROM [dbo].[Products] AS [t0]
Where [t0].[UnitPrice] > 99

查詢句法 - 理解延遲執行(Deferred Execution)和使用ToList() 和ToArray()

在默認情形下,查詢句法表達式的結果的類型是IEnumerableT>。在上面的例子里,你會注意到所有的查詢句法賦值是給IEnumerableProduct>, IEnumerablestring>, IEnumerablePerson>, IEnumerableAlternatePerson>, 和 IEnumerableMyProduct> 變量的。

IEnumerableT>接口的一個很好的特征是,實現它們的對象可以把實際的查詢運算延遲到開發人員第一次試圖對返回值進行迭代(這是通過使用最早在VS 2005中C# 2.0 中引進的yield構造來達成的)時才進行。LINQ和查詢句法表達式利用了這個特性,將查詢的實際運算延遲到了你第一次對返回值進行循環時才進行。假如你對IEnumerableT>的結果從不進行迭代的話,那么查詢根本就不會執行。

譬如,考慮下面這個LINQ到SQL的例子:

不是在查詢句法表達式聲明的時候,而是在我們第一次試圖對結果進行循環(上面紅箭頭標志的地方),才會去訪問數據庫以及取出填充Category對象所需的值。

這個延遲運算的行為結果變得非常有用,因為它促成了一些把多個LINQ查詢和表達式鏈在一起的強有力的組合場景。譬如,我們可以把一個表達式的結果喂給另一個表達式,然后通過延遲運算,允許象LINQ 到SQL這樣的ORM根據整個表達式樹來優化raw SQL。我將在以后的一個博客貼子里對這樣的場景做示范說明。

如何立刻對查詢句法表達式做運算

如果你不要延遲查詢運算,而是要對它們立刻就執行運算,你可以使用內置的ToList() 和ToArray() 運算符來返回一個包括了結果集的ListT>或者數組。

譬如,要返回一個基于范型的 ListT> 集合的話:

要返回一個數組的話:

在上面兩種情形下,會立刻訪問數據庫,填充Category對象。

結語

查詢句法在使用標準的LINQ查詢運算符來表達查詢時,提供了非常方便的聲明式簡化寫法。它提供的句法可讀性非常高,可以針對任何類型的數據(內存中的集合,數組,XML內容,以及象數據庫這樣的遠程數據提供器,web服務等等)進行查詢。一旦你熟悉這個句法后,你可以在任何地方應用這個知識。

在不遠的將來,我將結束本語言系列的最后一部分,該部分將討論新的匿名類型特性。然后我將轉而討論在實際應用中使用所有這些語言特性的一些非常實用的例子(特別是針對數據庫和XML文件使用LINQ的例子)。

希望本文對你有所幫助,

Scott

標簽:通化 襄陽 嘉峪關 南平 聊城 南平 股票投資 池州

巨人網絡通訊聲明:本文標題《新Orcas語言特性-查詢句法》,本文關鍵詞  新,Orcas,語言,特性,查詢,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《新Orcas語言特性-查詢句法》相關的同類信息!
  • 本頁收集關于新Orcas語言特性-查詢句法的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    日韩午夜中文字幕| 久久精品亚洲一区二区三区浴池| 91久久国产最好的精华液| 欧美电影免费观看高清完整版在线 | 日韩一区二区在线播放| 亚洲3atv精品一区二区三区| 在线播放日韩导航| 麻豆91免费看| 久久久亚洲精品一区二区三区 | 狠狠色综合日日| 日韩一区二区视频在线观看| 久久超碰97中文字幕| 久久久精品蜜桃| 91香蕉视频黄| 三级精品在线观看| 欧美本精品男人aⅴ天堂| 国产自产v一区二区三区c| 国产精品网站在线播放| 色欧美片视频在线观看| 图片区日韩欧美亚洲| 欧美一区二区免费视频| 国产成人av电影免费在线观看| 国产欧美一二三区| 色偷偷成人一区二区三区91| 亚洲国产精品天堂| 精品美女一区二区| 色视频成人在线观看免| 狠狠色丁香久久婷婷综| 亚洲丝袜制服诱惑| 欧美男男青年gay1069videost | 91视频com| 国产精品美女久久久久高潮| 国产无人区一区二区三区| 9191成人精品久久| 91精品国产免费| 久久精品国产亚洲一区二区三区| 欧美国产一区在线| 97国产一区二区| 丝瓜av网站精品一区二区| 欧美精彩视频一区二区三区| 精品视频一区二区三区免费| 另类小说综合欧美亚洲| 久久精品日产第一区二区三区高清版 | 国产99久久久精品| 亚洲一区二区三区小说| 久久久高清一区二区三区| 97se亚洲国产综合自在线不卡| 日本成人中文字幕| 亚洲免费在线观看视频| 欧美国产1区2区| 欧美一区二区三区视频| 日本高清视频一区二区| 成人精品视频一区二区三区尤物| 五月天一区二区三区| 亚洲丝袜制服诱惑| 欧美国产日韩亚洲一区| 日韩欧美久久久| 在线观看亚洲一区| 99精品视频在线免费观看| 国产一区二区三区视频在线播放| 亚洲国产视频a| 国产精品视频九色porn| 久久嫩草精品久久久精品| 欧美成人激情免费网| 欧美日韩日本视频| 7777精品伊人久久久大香线蕉经典版下载| 91蝌蚪国产九色| av在线不卡观看免费观看| 国产成人免费视频一区| 美国欧美日韩国产在线播放| 免费的国产精品| 午夜一区二区三区视频| 午夜在线成人av| 视频一区欧美精品| 日本aⅴ精品一区二区三区| 三级影片在线观看欧美日韩一区二区| 婷婷激情综合网| 美国毛片一区二区| 国产一区二区三区免费观看| 蜜臀国产一区二区三区在线播放| 三级久久三级久久| 美女www一区二区| 国产丶欧美丶日本不卡视频| 成人免费电影视频| 91蜜桃视频在线| 欧美日韩国产高清一区二区| 欧美一区二区三区男人的天堂| 日韩一级高清毛片| 欧美精品一区二区不卡| 国产精品毛片大码女人| 一区二区成人在线观看| 肉丝袜脚交视频一区二区| 精品伊人久久久久7777人| 国产一区二区三区免费观看| 国产福利一区在线观看| 波多野结衣中文字幕一区二区三区 | 亚洲午夜久久久| 日本欧美一区二区三区| 国产一区二区在线看| jizz一区二区| 欧美二区三区91| 国产精品久久久久影院老司| 午夜伦欧美伦电影理论片| 国产一区二区三区av电影| 色综合久久久久综合体桃花网| 欧美浪妇xxxx高跟鞋交| 久久五月婷婷丁香社区| 一级做a爱片久久| 国内精品国产三级国产a久久| 色综合久久综合| 国产视频不卡一区| 日韩1区2区日韩1区2区| 粉嫩欧美一区二区三区高清影视 | 色狠狠桃花综合| 精品福利一区二区三区| 亚洲精品日韩综合观看成人91| 免费av成人在线| 色婷婷精品久久二区二区蜜臀av| 精品三级在线观看| 一区二区三区在线观看欧美| 高清av一区二区| 精品国产sm最大网站免费看| 五月婷婷综合在线| 欧美综合色免费| 中文字幕日韩一区| 国产麻豆9l精品三级站| 欧美一二三区在线| 日韩中文字幕区一区有砖一区| 91麻豆免费在线观看| 国产日韩欧美亚洲| 国产真实乱子伦精品视频| 欧美久久一区二区| 亚洲图片欧美综合| 欧美天堂亚洲电影院在线播放| 日韩美女视频一区| heyzo一本久久综合| 国产精品理伦片| 粗大黑人巨茎大战欧美成人| 欧美国产日本韩| eeuss国产一区二区三区| 中文字幕高清不卡| 国产夫妻精品视频| 国产精品素人一区二区| 99久久伊人精品| 成人免费一区二区三区在线观看| av中文字幕在线不卡| 亚洲日本va在线观看| 日本精品一区二区三区高清| 亚洲一区国产视频| 欧美午夜精品免费| 亚洲成av人影院| 91精品国产色综合久久不卡蜜臀 | 岛国av在线一区| 国产精品久久久久久一区二区三区 | 椎名由奈av一区二区三区| 99久久综合色| 亚洲一区在线视频观看| 欧美最新大片在线看| 日韩精品成人一区二区三区| 69av一区二区三区| 国产在线播放一区| 国产精品久久久久久亚洲毛片 | 国产成人啪免费观看软件| 国产精品毛片高清在线完整版| 一本久道中文字幕精品亚洲嫩| 午夜精品福利一区二区三区蜜桃| 欧美成va人片在线观看| 国产剧情av麻豆香蕉精品| 国产女主播一区| 日本丰满少妇一区二区三区| 五月婷婷综合网| 日本一区二区三区久久久久久久久不 | 亚洲国产日韩综合久久精品| 欧美日韩的一区二区| 奇米精品一区二区三区在线观看| 精品久久久久一区二区国产| 色综合久久中文综合久久牛| 美女精品一区二区| 国产精品国产三级国产普通话99| 欧美精品亚洲一区二区在线播放| 国产一区二区伦理| 亚洲欧美乱综合| 精品国产91九色蝌蚪| 在线观看视频91| 国产在线精品一区在线观看麻豆| 18成人在线观看| 精品国产网站在线观看| 91视频在线观看| av资源站一区| 久久国产精品72免费观看| 亚洲精选视频免费看| 久久夜色精品一区| 欧美日韩高清在线| 色狠狠综合天天综合综合| 粉嫩一区二区三区在线看| 免费在线成人网| 午夜伊人狠狠久久| 一区二区三区成人| 国产精品三级电影| 久久综合视频网|