日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
LINQ語法學(xué)習(xí)經(jīng)驗

學(xué)習(xí)LINQ時,經(jīng)常會遇到LINQ語法問題,這里將介紹LINQ語法問題的解決方法,以及介紹LINQ 是一系列語言延伸模塊,以型別安全的方式支持?jǐn)?shù)據(jù)查詢。

成都創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供海港網(wǎng)站建設(shè)、海港做網(wǎng)站、海港網(wǎng)站設(shè)計、海港網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、海港企業(yè)網(wǎng)站模板建站服務(wù),10多年海港做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。

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

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

LINQ 藉由各語言編譯程序?qū)?nèi)嵌的 LINQ語法轉(zhuǎn)譯成原本的 C# 或 VB.NET 程序代碼,并呼叫相關(guān)的底層模塊以實體維護(hù)數(shù)據(jù)。***編譯成與 .NET Framework 2.0 CLR 兼容的 IL,所以 CLR 本身并未增加與 LINQ 相關(guān)的模塊,但 .NET Framework、Visual Studio 整合開發(fā)環(huán)境和程序語言需要增加相關(guān)功能和語法。

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

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

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

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

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

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

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

LINQ 范例

你可以在 C# 中直接內(nèi)嵌如下的語法:取得在 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語法經(jīng)由 C# 編譯程序解析,傳回實做 IEnumerable 接口的對象給 matchCustomers 變量。而在查詢語法中,呼叫了 where、orderby、select 等延伸方法(Extension Methods)。并定義匿名方法(Anonymous Methods)的委派(delegate);要求 where 方法比較 Customers 集合中 Customer 對象的 Country 屬性值為 USA。換句話說,自動將 c.Country == "USA" 轉(zhuǎn)成 bool Pred(T item) 形式的委派。***透過 select 延伸方法搭配對象初始化表達(dá)式,回傳匿名型別(Anonymous Type)對象的集合。

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

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

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

【編輯推薦】

  1. LINQ to SQL Table淺談
  2. Linq語句問題的解決方法
  3. Ling to sql更新實體概述
  4. Linq實體繼承簡單描述
  5. Linq Library概述

新聞名稱:LINQ語法學(xué)習(xí)經(jīng)驗
網(wǎng)站路徑:http://www.dlmjj.cn/article/cdoichg.html