欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

LINQ,語言級集成查詢(Language INtegrated Qu

系統 1671 0

LINQ

基本概念

LINQ ,語言級集成查詢( L anguage IN tegrated Q uery)
  經過了最近 20 年,面向對象編程技術( object-oriented (OO) programming technologies )在工業領域的應用已經進入了一個穩定的發展階段。程序員現在都已經認同像 類(classes)、對象(objects)、方法(methods)這樣的語言特性。考察現在和下一代的技術,一個新的編程技術的重大挑戰開始呈現出來,即面向對象技術誕生以來并沒有解決降低訪問和整合信息數據( accessing and integrating information )的復雜度的問題。其中兩個最主要訪問的數據源與數據庫( database )和 XML 相關。
  LINQ 提供了一條更常規的途徑即給 .Net Framework 添加一些可以應用于所有信息源( all sources of information )的具有多種用途( general-purpose )的語法查詢特性( query facilities ),這是比向開發語言和運行時( runtime )添加一些關系數據( relational )特性或者類似 XML 特性( XML-specific )更好的方式。這些語法特性就叫做 .NET Language Integrated Query (LINQ) 。
  包含 DLinq 和 XLinq

語法實例

  C#3.0 LINQ 查詢語法
  首先來看一個很簡單的LINQ查詢例子,查詢一個int 數組中小于5的數字,并按照大小順序排列:
  class Program
  {
  static void Main(string[] args)
  {
  int[] arr = new int[] { 8, 5, 89, 3, 56, 4, 1, 58 };
  var m = from n in arr where n < 5 orderby n select n;
  foreach (var n in m)
  {
  Console.WriteLine(n);
  }
  Console.ReadLine();
  }
  }
  上述代碼除了LINQ查詢語法外,其他都是我們所熟悉的語法,而LINQ查詢語法跟SQL查詢語法很相識,除了先后順序。
  Q:為何 LINQ 查詢語法是以 from 關鍵字開頭的,而不是以 select 關鍵字開頭的?select 開頭這種寫法跟SQL的寫法更接近,更易懂呀?
  A:簡單來說,為了IDE的智能感知(Intelisence)這個功能,select 關鍵字放在后面了。
  編程語言以 select 開頭寫LINQ查詢語法不是沒出現過,你如果使用過2005年的VB9 CTP 版本,那時候VB9的LINQ查詢語法就是 select 關鍵字在前面,但是 select 關鍵字在前面,在做智能感知(Intelisence)時候就很頭大。經過微軟IDE組的權衡,確定了把 from 關鍵字放在最前面。
  比如:你看 http://blog.joycode.com/saucer/archive/2005/09/16/63513.aspx 這篇博客,那時候 VB9 LINQ的查詢語法還是 select 參數在最前面。不過后來 VB9 測試版改成了跟 C# 一樣的做法, from 關鍵字放在最前面了。
  更詳細的解釋,來自裝配腦袋
  假設你要書寫這樣的代碼:Select p.Name, p.Age From p In persons Where xxx ,代碼是一個個字符輸入的。
  我們在寫到 p in persons 之前,p 的類型是無法推測的,所以寫 Select p. 的時候,Name之類的屬性不會彈出智能提示來。
  這樣就需要先去寫 From 這句,再回來寫 Select。
  微軟IDE組經過反復考慮決定,還不如就把 Select 寫到后面了。于是編程語言中的寫法就確定這樣來寫了。
  VB9 的這個變化可以參看這篇博客:
  Select/From vs. From/Select revisited...
  我們再來看一個稍稍復雜的LINQ查詢:
  在我們羅列的語言字符串中,我們希望按照字符長短,分類羅列出來,實現代碼如下:
  static void Main(string[] args)
  {
  string [] languages = {"Java","C#","C++","Delphi","VB.net","VC.net","C++ Builder","Kylix","Perl","Python"};
  var query = from item in languages
  orderby item
  group item by item.Length into lengthGroups
  orderby lengthGroups.Key descending
  select lengthGroups;
  foreach (var item in query)
  {
  Console.WriteLine("strings of length ",item.Key);
  foreach (var val in item)
  {
  Console.WriteLine(val);
  }
  }
  Console.ReadLine();
  }
  其中的 into 關鍵字表示 將前一個查詢的結果視為后續查詢的生成器,這里是跟 group by 一起使用的。
  LINQ中的Group by不要跟 SQL 中的Group by 混淆,SQL 由于是二維結構,Group by 的一些邏輯受二維結構的約束,無法象 LINQ 中的Group by 這么靈活。

Linq的內部執行原理淺析

  LINQ(Language Integrated Query)是Visual Studio 2008中的領軍人物。借助于LINQ技術,我們可以使用一種類似SQL的語法來查詢任何形式的數據。目前為止LINQ所支持的數據源有SQL Server、XML以及內存中的數據集合。開發人員也可以使用其提供的擴展框架添加更多的數據源,例如MySQL、Amazon甚至是Google Desktop。
  一般來講,這類查詢語句的一個重要特點就是可以并行化執行。雖然有些情況下并行可能會帶來一些問題,但這種情況非常少見。這樣也就水到渠成地引出了PLINQ這個并行處理的LINQ類庫。
  PLINQ原名為Parallel LINQ,支持XML和內存中的數據集合。執行于遠程服務器上的查詢語句(例如LINQ to SQL)顯然無法實現這個功能。
  將LINQ語句轉換為PLINQ語句極為簡單——只需要在查詢語句中From子句所指定的數據源的最后添加.AsParallel()即可。隨后Where、OrderBy和Select子句將自動改為調用這個并行的LINQ版本。
  據MSDN Magazine介紹,PLINQ可以以三種方式執行。第一種是管道處理:一個線程用來讀取數據源,而其他的線程則用來處理查詢語句,二者同步進行——雖然這個單一的消費線程可能并不那么容易與多個生產線程同步。不過若是能夠仔細配置好負載平衡的話,仍然會極大地減少內存占用。
  第二種模式叫做“stop and go”,用于處理結果集需要被一次返回時(例如調用ToList、ToArray或對結果排序)的情況。在這種模式下,將依次完成各個處理過程,并將結果統一返回給消費線程。這個模式在性能上將優于第一種模式,因為它省去了用來保持線程同步所花費的開銷。
  最后一種方法叫做“inverted enumeration”。該方法并不需要實現收集到所有的輸出,然后在單一的線程中處理,而是將最終調用的函數通過ForAll擴展傳遞到每個線程中。這是目前為止最快的一種處理模式,不過這需要傳遞到ForAll中的函數是線程安全的,且最好不包含任何lock之類的互斥語句。
  若是PLINQ中任意的一個線程拋出異常,那么所有的其他線程將會被終止。若是拋出了多個異常,那么這些異常將被組合成一個MultipleFailuresException類型的異常,但每個異常的調用堆棧仍會被保留。
  補充(Trueman):
  感覺C#設計人員對LINQ的語法考慮欠佳,我對LINQ涉獵不深,但是舉例說明我對LINQ語法設計的考慮:
  問題:從int數組a中選擇范圍在18~28之間的值,并按照升序輸出int數組b
  已知:int[] a;
  解決:int[] b = SQL{select int from a where int >= 18 and int <= 28 order by int};
  問題:從結構體Point列表a中選擇距離Point O不超過單位100的Point列表b
  已知:List<Point> a; Point O; 函數float Distance(Point A, Point B);
  解決:List<Point> b = SQL{select Point from a where Distance(Point, O) <= 100};
  問題:將字符串s中所有數字設置為字符'0'
  已知:string s; 設char[] chars = s.ToCharArray();
  解決:char[] result = SQL{update chars set char = '0' where char >= '0' and char <= '9'};
  問題:在byte數組a后插入255,形成新的數組b
  已知:byte[] a;
  解決:byte[] b = SQL{insert into a values(255)};
  問題:刪除int數組a中的負值,形成新的數組b
  已知:int[] a;
  解決:int[] b = SQL{delete int from a where int < 0};

LINQ,語言級集成查詢(Language INtegrated Query)


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 久久久久国产精品免费免费搜索 | 一级女性大黄生活片免费 | 欧洲精品久久久 | a毛片成人免费全部播放 | 国产精品亚洲综合一区在线观看 | 狠狠色丁香婷婷综合久久来 | 欧美zzzz | 爱人同志国语免费观看全集 | 视频一区二区三区四区五区 | 久久成人国产精品免费 | 牛牛精品国内免费一区 | 青春草在线观看 | 九九99九九在线精品视频 | 日本精a在线观看 | 午夜亚洲精品 | 91亚洲精品成人一区 | 草久久免费视频 | 亚洲第一页在线播放 | 成年视频网站免费观看 | 免费小视频 | 国产精品三级国语在线看 | 嫩草嫩草嫩草 | 日本黄 色 成 年 人免费观看 | 免费色网址 | 最新高清无码专区 | 日韩a级片| 久久久久无码国产精品一区 | 欧美高清视频一区 | 精品亚洲永久免费精品 | 亚洲精品不卡久久久久久 | 欧美极品在线观看 | 一级毛片aaaaaa视频免费看 | 天天搞天天搞 | 91福利免费体验区观看区 | 男女性关系视频免费观看软件 | 天天躁日日躁aaaa视频 | 啪啪免费| A片好大好紧好爽视频 | 国产亚洲精品久久一区二区三区 | 亚洲 中文 欧美 日韩 在线观看 | 成人免费大片a毛片 |