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

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

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

在選擇Enterprise Library版本的時候,我一直都是相對謹慎,由於咱們開發的項目涉及不少不一樣的系統,有的須要XP的支持、有的須要Win7的支持或者Win10等等,須要考慮不一樣系統之家的兼容問題,因爲微軟企業庫中的數據庫訪問模塊相對比較穩定,所以也基本沿用使用穩定的版本,雖然目前Enterprise Library版本爲6.0,可是以前一直在項目中使用的是3.1,這個版本能夠在.NET 2.0的項目上運行,並且擴展類庫也比較不錯,所以一直保留着。mysql

隨着框架版本的升級,在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、DB二、MySql、ODP.NET(Oracle)、PostgreSQL、SQLite、SqlEx等數據庫,而Enterprise Library 5.0版本擴展類庫的支持尚未完整提供,須要本身處理。sql

所以綜合上面的緣由,咱們爲了照顧XP、Win7/Win8/Win10等不一樣系統的兼容性,能夠從目前的Enterprise Library 3.1升級到Enterprise Library 4.1,這樣能夠利用較好的擴展類庫的支持(支持支持了SQLServer、DB二、MySql、ODP.NET(Oracle)、PostgreSQL、SQLite、SqlEx等數據庫),也相對提升下該數據訪問模塊的版本。數據庫

在我之前繪製的多數據庫支持裏面調整一下,把咱們採用微軟企業庫後,支持的數據庫做爲數據層,示意圖以下所示。編程

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

 

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

採用了微軟企業庫Enterprise Library做爲咱們底層的數據庫訪問模塊後,對於多種數據庫的訪問操做,就會統一採用這個企業庫的數據庫訪問對象,操做起來很是一致,爲了對不一樣數據庫的常規增刪改查等一些操做進行進一步的封裝,已達到簡化代碼的目的,所以咱們能夠爲每一個不一樣的數據庫定義一個數據訪問操做基類,以便實現一些不一樣數據庫差別性的處理,可是它們仍是有一個共同的數據訪問基類。app

採用不一樣的數據庫,咱們須要爲不一樣數據庫的訪問層進行生成處理,如爲SQLServer數據的表生成相關的數據訪問層DALSQL,裏面放置各個表對象的內容,不過因爲採用了相關的繼承類處理和基於數據庫的代碼生成,須要調整的代碼不多。框架

針對數據訪問層,咱們須要設計好對應的繼承關係,以便使得咱們的基類可以封裝大多數的操做,並給子類相對的彈性處理空間,如對於客戶Customer的對象,數據接口層和數據訪問實現層的關係以下所示。ide

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

關於這個架構,我在前面不少文章都有闡述,若是咱們還須要擴展一些特殊的數據庫支持,能夠參考隨筆《基於Enterprise Library的Winform開發框架實現支持國產達夢數據庫的擴展操做》進行一些擴展定製的操做。

 

三、基於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開發項目,以及一些後臺服務項目上運行良好,並使用了多年,爲咱們開發各類不一樣數據庫,或者升級到不一樣數據庫版本的處理工做上立下了汗馬功勞。

相關文章
相關標籤/搜索