在資料庫訪問項目中使用微軟企業庫Enterprise Library,實現多種資料庫的支持

来源:http://www.cnblogs.com/wuhuacong/archive/2016/09/12/5866722.html
-Advertisement-
Play Games

在我們開發很多項目中,數據訪問都是必不可少的,有的需要訪問Oracle、SQLServer、Mysql這些常規的資料庫,也有可能訪問SQLite、Access,或者一些我們可能不常用的PostgreSQL、IBM DB2、或者國產達夢資料庫等等,這些資料庫的共同特點是關係型資料庫,基本上開發的模型都... ...


在我們開發很多項目中,數據訪問都是必不可少的,有的需要訪問Oracle、SQLServer、Mysql這些常規的資料庫,也有可能訪問SQLite、Access,或者一些我們可能不常用的PostgreSQL、IBM DB2、或者國產達夢資料庫等等,這些資料庫的共同特點是關係型資料庫,基本上開發的模型都差不多,不過如果我們基於ADO.NET的基礎上進行開發的話,那麼各種資料庫都有自己不同的資料庫操作對象,微軟企業庫Enterprise Library是基於這些不同資料庫的操作做的抽象模型,適合多資料庫的支持項目。本文介紹基於微軟企業庫Enterprise Library 4.1的基礎進行的多種資料庫的處理。

1、企業庫Enterprise Library版本的選擇

在選擇Enterprise Library版本的時候,我一直都是相對謹慎,因為我們開發的項目涉及很多不同的系統,有的需要XP的支持、有的需要Win7的支持或者Win10等等,需要考慮不同系統之家的相容問題,由於微軟企業庫中的資料庫訪問模塊相對比較穩定,因此也基本沿用使用穩定的版本,雖然目前Enterprise Library版本為6.0,但是之前一直在項目中使用的是3.1,這個版本可以在.NET 2.0的項目上運行,而且擴展類庫也比較不錯,因此一直保留著。

隨著框架版本的升級,在XP上最高可以運行.NET 4.0的版本,因此可以考慮使用Enterprise Library 4.1或者5.0的版本(Enterprise Library 6.0版本需要.NET 4.5的支持,無法再XP上運行),相對來說,Enterprise Library4.1的擴展類庫支持非常不錯(http://entlibcontrib.codeplex.com/releases/view/38988),支持了SQLServer、DB2、MySql、ODP.NET(Oracle)、PostgreSQL、SQLite、SqlEx等資料庫,而Enterprise Library 5.0版本擴展類庫的支持還沒有完整提供,需要自己處理。

因此綜合上面的原因,我們為了照顧XP、Win7/Win8/Win10等不同系統的相容性,可以從目前的Enterprise Library 3.1升級到Enterprise Library 4.1,這樣可以利用較好的擴展類庫的支持(支持支持了SQLServer、DB2、MySql、ODP.NET(Oracle)、PostgreSQL、SQLite、SqlEx等資料庫),也相對提高下該數據訪問模塊的版本。

在我以前繪製的多資料庫支持裡面調整一下,把我們採用微軟企業庫後,支持的資料庫作為數據層,示意圖如下所示。

這樣基本上常規的關係型資料庫我們都支持了,我們需要開發任何資料庫應用,都是統一數據模型,開發起來方便很多了,同時也方便在不同資料庫管理系統中進行配置切換。

 

2、採用微軟企業庫進行架構設計

採用了微軟企業庫Enterprise Library作為我們底層的資料庫訪問模塊後,對於多種資料庫的訪問操作,就會統一採用這個企業庫的資料庫訪問對象,操作起來非常一致,為了對不同資料庫的常規增刪改查等一些操作進行進一步的封裝,已達到簡化代碼的目的,因此我們可以為每個不同的資料庫定義一個數據訪問操作基類,以便實現一些不同資料庫差異性的處理,但是它們還是有一個共同的數據訪問基類。

採用不同的資料庫,我們需要為不同資料庫的訪問層進行生成處理,如為SQLServer數據的表生成相關的數據訪問層DALSQL,裡面放置各個表對象的內容,不過由於採用了相關的繼承類處理和基於資料庫的代碼生成,需要調整的代碼很少。

針對數據訪問層,我們需要設計好對應的繼承關係,以便使得我們的基類能夠封裝大多數的操作,並給子類相對的彈性處理空間,如對於客戶Customer的對象,數據介面層和數據訪問實現層的關係如下所示。

這樣整合多種資料庫支持的底層後,整個數據訪問的架構設計如下所示。

關於這個架構,我在前面很多文章都有闡述,如果我們還需要擴展一些特殊的資料庫支持,可以參考隨筆《基於Enterprise Library的Winform開發框架實現支持國產達夢資料庫的擴展操作》進行一些擴展定製的操作。

 

3、基於Enterprise Library的多種資料庫支持處理

前面我們提到,使用微軟企業庫Enterprise Library的好處就是可以統一編程模型,實現對多種資料庫的相容處理,而微軟企業庫Enterprise Library最大的特點是基於配置項實現多種資料庫的處理,通過對使用不同的配置項,就可以迅速切換到對應的資料庫上來,代碼不需要修改。

對於一般的企業庫配置處理,我們增加配置項如下所示。

  <configSections>
    <section name="dataConfiguration" type="Microsoft.Practices.EnterpriseLibrary.Data.Configuration.DatabaseSettings, Microsoft.Practices.EnterpriseLibrary.Data"/>
  </configSections>

然後為不同的資料庫添加不同的連接字元串

對於預設支持的SQLServer資料庫,它的連接字元串如下所示。

<?xml version="1.0"?>
<configuration>
  <configSections>
    <section name="dataConfiguration" type="Microsoft.Practices.EnterpriseLibrary.Data.Configuration.DatabaseSettings, Microsoft.Practices.EnterpriseLibrary.Data"/>
  </configSections>
  <connectionStrings>
    <!--SQLServer資料庫的連接字元串-->
    <add name="sqlserver" providerName="System.Data.SqlClient" connectionString="Persist Security Info=False;Data Source=(local);Initial Catalog=WinFramework;Integrated Security=SSPI"/>
  </connectionStrings>
  <dataConfiguration defaultDatabase="sqlserver">
  </dataConfiguration>
</configuration>

不過對於一些擴展支持的資料庫,我們還需要添加一些映射處理,如對於MySQL的支持,我們需要添加連接字元串:

    <!--MySQL資料庫的連接字元串-->
    <add name="mysql" providerName="MySql.Data.MySqlClient" connectionString="Server=localhost;Database=WinFramework;Uid=root;Pwd=123456;"/>

還需要添加ProviderMappings的支持,如下所示的XML。

  <dataConfiguration defaultDatabase="mysql">
    <providerMappings>
      <add databaseType="EntLibContrib.Data.MySql.MySqlDatabase, EntLibContrib.Data.MySql" name="MySql.Data.MySqlClient" />
    </providerMappings>
  </dataConfiguration>

下麵我列出所有不同資料庫的連接字元串以及映射關係的一個完整版本,供參考。

前面我們提到了,基於配置實現不同資料庫的統一處理,我們為了測試不同資料庫的連接,我們可以使用下麵的簡單案例代碼來獲取數據進行展示。

其實現的代碼如下所示。

我們看到,上面的代碼沒有針對具體的資料庫,因此也是非常通用的處理,我們可以直接獲取數據並展示出來,我上面案例在SQLServer、Oracle、PostgreSQL、MySQL、SQLite、Access、IBM DB2資料庫均測試通過。

具體開發項目的時候,不同資料庫有一些不同的處理,如分頁操作、獲取指定記錄的處理等等,這些我們就需要發揮上面提到的資料庫基類的功能了,通過基類功能的封裝,我們可以除了可以使用所有資料庫的共性外,還可以使用它的一些特定處理操作,這樣我們就可以充分利用各種不同資料庫的特點,但是又統一到一個開發模型上來,降低了各種不同資料庫之間開發的成本,同時也減少不同資料庫之間的遷移難度,提高代碼的可閱讀性和可擴展性。

上面關於資料庫訪問模塊的框架構建,已經在我眾多的Winform項目、Web開發項目,以及一些後臺服務項目上運行良好,並使用了多年,為我們開發各種不同資料庫,或者升級到不同資料庫版本的處理工作上立下了汗馬功勞。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 最近由於在做一個眾籌的項目,其中有一個查找項目支持數的介面,查找的方法定義的是一個long型的,我更新項目中的支持數的時候是int型的,所以需要在long型與int型之間轉化,下麵把轉轉化的詳細方法記錄一下,以便後面總結學習: 一.將long型轉化為int型,這裡的long型是基礎類型: long ...
  • 這個,不管是什麼書都會這樣說,因為常常我們並不需要繼承,而只是想把類進行一定的擴展,而我們想擴展的屬性或方法對應的類都有,這個時候如果兩者是is a的關係,這種關係是確實存在的,那麼就可以使用繼承,不然一般都是建議使用複合。 如果我們隊一個類進行繼承的時候,我們如果對其內部的邏輯並不十分瞭解的時候, ...
  • 獲取類的名稱 獲取該類的方法 獲取方法的返回值類型 獲取方法的名稱 獲取方法的參數的類型 返回結果 ...
  • 建議26:提防包裝類型的null值 我們知道Java引入包裝類型(Wrapper Types)是為瞭解決基本類型的實例化問題,以便讓一個基本類型也能參與到面向對象的編程世界中。而在Java5中泛型更是對基本類型說了"不",如果把一個整型放入List中,就必須使用Integer包裝類型。我們看一段代碼 ...
  • 合成存取方法 Objective-C從 OC 2.0版本開始,自動合成了setter 方法和 getter 方法。而且,如果開發者需要自己控制某個setter 方法和 getter 方法的實現時,可以自己提供 setter 方法和 getter 方法,自己提供的setter 方法和 getter 方 ...
  • 一、【前言】關於tarjan tarjan演算法是由Robert Tarjan提出的求解有向圖強連通分量的演算法。 那麼問題來了找藍翔!(劃掉)什麼是強連通分量? 我們定義:如果兩個頂點互相連通(即存在A到B和B到A的通路),則稱這兩個點強連通。對於一個有向圖G,若是G中任意兩點都強連通,則稱G是一個強 ...
  • 最近大家都在找工作,我好迷茫,覺得自己會的東西太少了。所以決定開始學習SSH三大框架。 首先是struts. struts是基於mvc模式的框架。(struts其實也是servlet封裝,提高開發效率!) Servlet起到控制器作用!主要可以: 》 獲取請求數據封裝 【BeanUtils可以優化, ...
  • 對於自己寫ORM時的感受以及遇到的難點總結,對於自己而言總是會更清晰的理解到不足。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...