日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

如何利用抽象工厂更换数据库

發布時間:2025/6/15 数据库 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 如何利用抽象工厂更换数据库 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
? ?VS中我們都加入了抽象工廠模式,都懂的這種模式可以用來更換數據庫。具體應用起來大家都知道應用反射,首先我介紹下我的情況吧。

? ?現在的情況是我的D層程序集和命名空間都為DAL,D層的類也都是以Sql為前綴來命名,例如SqlCancelCardDAL,在工廠中,我的代碼時這么寫的,大家可以看一下:

[vb]?view plaincopy
  • <span?style="font-size:18px;">Imports?DFactory??
  • Imports?IDAL??
  • Imports?System.Reflection??
  • Imports?System.Configuration??
  • ??
  • Public?Class?DataAccess?????
  • ????Private?ReadOnly?assemblyName?As?String?=?"DAL"??
  • ????Dim?strDB?As?String?=?System.Configuration.ConfigurationSettings.AppSettings("DB")??
  • ??
  • ????'返回一個IStudent接口??
  • ????Public?Function?CheckStuID()?As?IStudent??
  • ????????Dim?ClassName?As?String?=?assemblyName?+?"."?+?strDB?+?"StuInfoDAL"??
  • ????????Return?CType(Assembly.Load("DAL").CreateInstance(ClassName),?IStudent)??
  • ????End?Function??
  • ??
  • ????'返回注冊接口IRegist??
  • ????Public?Function?AboutRegist()?As?IRegist??
  • ????????Dim?ClassName?As?String?=?assemblyName?+?"."?+?strDB?+?"RegistDAL"??
  • ????????Return?CType(Assembly.Load("DAL").CreateInstance(ClassName),?IRegist)??
  • ????End?Function??
  • ??
  • ????'返回充值接口ICharge??
  • ????Public?Function?InsertInfo()?As?ICharge??
  • ????????Dim?ClassName?As?String?=?assemblyName?+?"."?+?strDB?+?"ChargeDAL"??
  • ????????Return?CType(Assembly.Load("DAL").CreateInstance(ClassName),?ICharge)??
  • ????End?Function??
  • ???......??
  • ??End?Class??
  • </span>??

  • App.config中反射為:

    [vb]?view plaincopy
  • <add?key="DB"?value="Sql"/>??
  • 改變為??
  • <add?key="DB"?value="Oracle"/>??

  • ? ? 接著想,我們原來的命名空間跟改變的OracleDAO命名空間完全不一樣,看一下原來的工廠代碼這樣寫的:

    [vb]?view plaincopy
  • Private?ReadOnly?assemblyName?As?String?=?"DAL"??

  • ? ? 這樣就在程序里把命名空間給寫死了,但是我們同樣可以利用反射的原理將命名空間移動到XML中,不需要打開VS來看,因為我們的運行都是從項目文件中UI層Debug開始的,所以只需在UI\bin\Debug\UI.exe.config中添加一句:

    [vb]?view plaincopy
  • <add?key="MM"?value="OracleDAO"/>??

  • ? 同時在工廠層中將寫死的命名空間那句改為:

    [vb]?view plaincopy
  • Private?ReadOnly?assemblyName?=?System.Configuration.ConfigurationSettings.AppSettings("MM")??

  • ? ?最后一步就是:將每個方法中的return句中“DAL”改為assemblyName即為完美。

    ? ?這樣我們的程序如何更改數據庫只需在配置文件中更改命名空間和反射中類的前綴即可,這樣就充分運用了抽象工廠+反射,實現更換數據庫的功能。

    總結

    以上是生活随笔為你收集整理的如何利用抽象工厂更换数据库的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。