PetShop是如何兼容數據庫的

數據庫的移植通常會帶來高額的代價。這一點我深有體會。代價的大小就要看程序的架構寫的怎麼樣了. 去年把一個項目從MySQL移至到Oracle, 整個程序裏裏外外都做了修修補補,大概花了兩個月。

如果做到少修改,甚至不修改代碼的前提下,對數據庫的兼容無疑是一件非常好的事情,

PetShop很好的做到了這一點

要兼容多種數據庫,首先要實現多態。SQLServerDAL和OracleDAL都實現了IDAL裏所有接口的方法,實現了多態性。

FactoryDAL用來創建DAL對象,

public static PetShop.IDAL.IAccount Create()

{

/// Look up the DAL implementation we should be using

string path = System.Configuration.ConfigurationSettings.AppSettings["WebDAL"];

string className = path ".Account";

// Using the evidence given in the config file load the appropriate assembly and class

return (PetShop.IDAL.IAccount) Assembly.Load(path).CreateInstance(className);

}

如上:創建Account, 首先獲取Web.config 中的WebDAL的值。

<add key="WebDAL" value="PetShop.SQLServerDAL" />

Web.Config裏”WebDAL”的值是PetShop.SQLServerDAL,該值決定了所要創建的DAL的路徑。

然後再用Assembly.CreateInstance()創建DAL實例.



若要使用Oracle數據庫, 只要把

<add key="WebDAL" value="PetShop.SQLServerDAL" />和

<add key="OrdersDAL" value="PetShop.SQLServerDAL" />

中的PetShop.SqlServerDAL改爲PetShop.OracleDAL就可以了。



而在BLL中,它不需要知道你使用那個數據庫。只是通過如下語句得到對象。

// Get an instance of the account DAL using the DALFactory

IAccount dal = PetShop.DALFactory.Account.Create();

無論使用什麼數據庫,BLL模塊都不需要修改。





擴展性: 若要兼容MySQL數據庫改怎麼辦?

寫一個MySQLDAL模塊,實現IDAL裏所有接口的方法。 再修改Web.config中的值即可。



PetShop提供了良好的可擴展性, 封閉了業務層的修改。很好的滿足了OCP(開放-封閉原則). 
 
發佈了67 篇原創文章 · 獲贊 2 · 訪問量 28萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章