sql2008bi與EDM & LINQ

zhengnx發表於2011-02-10
 Enterprise Data Modeling的縮寫,是企業資料模型,主要來體現企業的業務規則以及資訊。相對來說,還有資料模型,在IT行業中它更傾向於描述系統實現。
  EDM 還是 Enterprise Data Modeling, Enterprise Decision Management ,Enterprise Directory and Messaging 和 Entity Data Model 的簡寫
  Ed.M. 【詞典解釋】:縮寫詞 abbr. 1. =Lat. Education's Magister (Master of Education) 【拉】教育碩士;
  計算機用語:.NET 中的EDM是 Entity Data Model 實體資料模型
  實體資料模型 (EDM) 是一個規範,用於定義由在 實體框架 基礎上生成的應用程式使用的資料。使用 EDM 的應用程式在設計架構中定義應用程式域中的實體和關係。設計架構用於生成由應用程式程式碼使用的可程式設計類。在此模型中持久保留應用程式資料的儲存結構由另一個架構(稱為儲存架構)表示。對映規範用於連線設計架構儲存架構
  由於可程式設計物件模型是從設計架構中生成的並且儲存架構對映到設計架構,因此,對映規範可以有效地將可程式設計類連線到儲存結構。由 EDM 定義的實體可以透過資料讀取器以序列化格式讀取,也可以具體化為物件。具體化的物件可以在 CLR 語言中進行程式設計,並可以更新以及儲存,而不需要嵌入式 SQL 字串或其他資料庫語法。EDM 提供在 EDM 架構和對映規範中使用的基本實體和關係型別。開發人員可以根據需要擴充套件這些型別以支援應用程式設計。
  用於管理應用程式中的資料的多個範例全部具有重要的優勢。儲存模型已經過最佳化,可以高效地進行儲存和檢索。XML 支援跨平臺界限進行資料交換。物件導向的程式設計是用於開發應用程式的公認標準。這些模型都有用,但要在它們之間傳輸資料,可能需要與應用程式方案無關的多行程式碼。
  資料模型可能是以統一建模語言 (UML) 或在白板上以圖表進行的分析。無論採用哪種方法,都必須在概念上對資料型別、其屬性、資料型別之間的關係、有關資料的約束等進行整理,然後才能在應用程式程式碼中實現它們。EDM 擴充套件了應用程式設計人員用來在開發過程中描述資料的模型,並提供了 XML 語法以便用示意圖形式詳細描述結果。[@more@]

DFD

XDM

LINQ,語言整合查詢(Language INtegrated Query)是一組用於c#和Visual Basic語言的擴充套件。它允許編寫C#或者Visual Basic程式碼以查詢資料庫相同的方式操作記憶體資料。

目錄

基本概念
基礎知識
語法例項
Linq的內部執行原理淺析

基本概念

  從技術角度而言,LINQ定義了大約40個查詢運算子,如select、from、in、where以及orderby(C#)中。試用這些操作可以編寫查詢語句。不過,這些查詢還可以基於很多型別的資料,每個資料型別都需要一個單獨的LINQ型別。
  經過了最近 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

基礎知識

  1. LINQ的讀法:(1)lin k (2)lin q
  2. LINQ的關鍵詞:from, select, in, where, group by, order by …
  3. LINQ的注意點:必須以select或者是group by 結束。
  4. LINQ的語義:
  from 臨時變數 in 集合物件或資料庫物件
  where 條件表示式
  [order by條件]
  select 臨時變數中被查詢的值
  [group by 條件]
  LINQ的查詢返回值的型別是臨時變數的型別,可能是一個物件也可能是一個集合。並且LINQ的查詢表示式是在最近一次建立物件時才被編譯的。LINQ的查詢一般跟var關鍵字一起聯用 (什麼是var?匿名物件) 。
  5. LINQ的全稱:Language-Integrated Query
  6. LINQ的分類:LINQ to Object, LINQ to XML, LINQ to SQL, LINQ to DataSet,LINQ to ADO.NET
  7. 名稱空間:System.Linq;
  注意:Linq是在.NET Framework 3.5 中出現的技術,所以在建立新專案的時候必須要選3.5或者更高版本,否則無法使用。
  選擇3.5或更高版本的.NET Framework之後,建立的新專案中會自動包含System.Linq的名稱空間。

語法例項

  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 關鍵字放在最前面。
  那時候 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 {0}",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型別的異常,但每個異常的呼叫堆疊仍會被保留。
  關於LINQ的技巧從大的方面來看它能給開發團隊帶來的好處:
  1、無需複雜學習過程即可上手
  2、編寫更少程式碼即可建立完整應用。
  3、更快開發錯誤更少的應用程式
  4、無需求助奇怪的程式設計技巧就可合併資料來源。
  5、讓新開發者開發效率更高。
詞條圖冊更多圖冊
擴充套件閱讀:
開放分類:

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/7868752/viewspace-1045740/,如需轉載,請註明出處,否則將追究法律責任。

相關文章