成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

LINQ語法學習經驗

開發 后端
這里介紹LINQ語法經由 C# 編譯程序解析,傳回實做 IEnumerable<Anonymous Type> 接口的對象給 matchCustomers 變量。而在查詢語法中,呼叫了 where、orderby、select 等延伸方法(Extension Methods)。

學習LINQ時,經常會遇到LINQ語法問題,這里將介紹LINQ語法問題的解決方法,以及介紹LINQ 是一系列語言延伸模塊,以型別安全的方式支持數據查詢。

程序語言隨著時間演進,一再沉淀經驗與抽象后,以簡練直觀的語法解決具有共通特征的各式問題。Visual Studio 2008(程序代碼名稱為 Orcas)、C# 3.0 與 VB.NET 9.0 后將支持新的語法 Language Integrated Query(LINQ),想一體解決多樣的資料存取。它是由 Anders Hejlsberg 所主導。Anders 曾打造了 Turbo Pascal、Delphi、Visual J++、C# 等叫好叫座的產品,單憑這位殺手應用創造者的眼光,LINQ 就不可小覷。

LINQ 是一系列語言延伸模塊,以型別安全的方式支持數據查詢。期待隔絕各種數據的特性,不管是各廠家數據庫的 SQL 方言,或是 XML 的 DOM、XQuery 或 XPath,抑或是對象集合的屬性存取。以共通的方式完成數據操作,如:挑選、比對、排序、匯總…等等。期待減輕程序開發人員學習操作各種數據的負荷。

LINQ 藉由各語言編譯程序將內嵌的 LINQ語法轉譯成原本的 C# 或 VB.NET 程序代碼,并呼叫相關的底層模塊以實體維護數據。***編譯成與 .NET Framework 2.0 CLR 兼容的 IL,所以 CLR 本身并未增加與 LINQ 相關的模塊,但 .NET Framework、Visual Studio 整合開發環境和程序語言需要增加相關功能和語法。

就筆者自己的感覺,LINQ 有以下的好處:

◆簡化大量的細節運作,將如何(how)取得數據換成要操作什么(what)數據:這隱含存取優化交由專家來做,如 DB 引擎優化存取數據。

◆透過IEnumerable<T> 一致性地存取各種數據,并在查詢語法中互相整合:如 File System、操作系統的 process、Registry、對象集合、XML、DB...,所用的皆是對象,大家的屬性都是數據。換句話說,數據對象化,對象數據化,存取二者的語法與語意相同。

◆平行運算:若要處理大量數據,程序設計師不容易撰寫 for 循環還包含平行運算。但 LINQ 轉譯成 C# 或 VB.NET 的程序代碼時,可以平行運算的方式處理大量數據。

◆撰寫數據對象存取的過程中,可以 IntelliSense 和強型別檢查:相較于以往 ADO.NET 加上 SQL 語法,LINQ 比 typed dataset 直觀易懂,且應用更為廣泛。

就筆者與許多朋友聊到 LINQ 時,最多的詢問便是「未來是否不需要學 SQL 了?」個人認為,短時間不可能,LINQ 或許會減輕程序設計師對 SQL 的倚賴,但 LINQ 不會取代 SQL。它們各有一片天,LINQ 是程序設計師講的數據對象語言,SQL 是數據庫管理師對數據庫引擎講的語言,LINQ 是從應用程序處理數據的角度出發,但 SQL 關乎著整體數據庫服務器有效且安全地活著的每一個細節。

而緊接的問題通常是:「將數據以對象來包裝,透過 entity 類別間接存取數據,那是否會有效率問題?」這筆者無法回答,尚待真實世界來證明。

LINQ 范例

你可以在 C# 中直接內嵌如下的語法:取得在 Customer 對象集合中,每個 Customer 的屬性 Country 值為 USA,按照 City 屬性由大到小排序,傳回以 CompanyName 和 City 兩個屬性的字符串值所建立的新對象之集合:

  1. var matchCustomers = from c in db.Customers  
  2. where c.Country == "USA"  
  3. orderby c.City descending  
  4. select new { c.CompanyName, c.City }; 

這句 LINQ語法經由 C# 編譯程序解析,傳回實做 IEnumerable<Anonymous Type> 接口的對象給 matchCustomers 變量。而在查詢語法中,呼叫了 where、orderby、select 等延伸方法(Extension Methods)。并定義匿名方法(Anonymous Methods)的委派(delegate);要求 where 方法比較 Customers 集合中 Customer 對象的 Country 屬性值為 USA。換句話說,自動將 c.Country == "USA" 轉成 bool Pred<T>(T item) 形式的委派。***透過 select 延伸方法搭配對象初始化表達式,回傳匿名型別(Anonymous Type)對象的集合。

若不采用 LINQ 寫法,上述語法也可以寫成如下的方式:

  1. var matchCustomers = db.Customers.Where(c => c.Country == "USA").
    OrderByDescending(
    c => c.City).Select(c => new { c.CompanyName, c.City }); 

哇,想我修習 .NET 數年,竟不知所云!?在此介紹一本入門書:「Introducing Microsoft LINQ」,Microsoft Press 出版。它讓你了解以往的 C# 和 VB.NET 各版本如何漸進地增加功能,***演變出 LINQ語法。

【編輯推薦】

  1. LINQ to SQL Table淺談
  2. Linq語句問題的解決方法
  3. Ling to sql更新實體概述
  4. Linq實體繼承簡單描述
  5. Linq Library概述
責任編輯:佚名 來源: 博客園
相關推薦

2015-07-07 10:43:59

Swift語法基礎

2015-07-07 10:58:29

Swift語法高級

2010-05-27 17:56:39

MySQL存儲過程

2011-08-05 14:16:47

Objective-C 變量 方法

2011-08-18 15:19:28

XcodeObjective-C語法

2009-09-10 17:38:04

LINQ技術

2009-09-11 12:08:09

Linq to SQL

2009-09-07 17:09:45

Linq To Sql

2009-09-08 15:27:08

Linq Select

2009-09-16 17:13:54

學習Linq

2009-08-31 16:51:11

C# Main()方法

2009-08-27 09:27:49

C#擴展方法

2009-09-17 08:47:00

Linq查詢

2009-08-18 12:52:33

C#枚舉類型

2009-09-09 16:53:53

LINQ查詢語法

2009-09-14 09:55:55

Linq基本語法

2009-09-14 10:20:52

LINQ查詢語法

2009-09-11 13:29:31

LINQ查詢操作

2009-09-16 17:44:54

LINQ to SQL

2009-09-08 16:02:47

Linq使用Group
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 黄色免费在线观看网站 | 精品久久国产 | 自拍视频一区二区三区 | 亚洲网站在线观看 | 国内久久 | 91久久久久久 | 香蕉91| 91久久| 日韩国产免费观看 | 亚洲一区二区三区在线观看免费 | 亚洲综合三区 | 久久9视频| 日韩国产中文字幕 | 秋霞在线一区二区 | 成人国产一区二区三区精品麻豆 | 久久久久久久综合色一本 | 一区二区三区精品视频 | 国产综合网址 | 成人亚洲网站 | 成人av片在线观看 | 欧美h视频 | 亚洲高清一区二区三区 | 先锋av资源网 | 精品美女视频在线观看免费软件 | 麻豆av网站 | 国产精品久久精品 | 日韩在线xx| 一区二区三区成人 | 天天插天天狠天天透 | 亚洲精品自在在线观看 | 男人天堂网av | 国产精选一区 | 国产在线高清 | 欧美精品在线免费观看 | 91久久国产综合久久 | 国产一区91精品张津瑜 | 日韩视频精品在线 | 免费不卡一区 | 国产在线精品一区二区三区 | 国产福利在线 | 欧美一级免费看 |