如果做到少修改,甚至不修改代碼的前提下,對數據庫的兼容無疑是一件非常好的事情,
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(開放-封閉原則).