新聞中心
C# 泛型操作數(shù)據(jù)庫切換實(shí)踐的一個(gè)項(xiàng)目,最開始選用的是 MySql 5.0 數(shù)據(jù)庫,項(xiàng)目提交之后,對(duì)方要求換成 MS SQLServer 2000,還好數(shù)據(jù)層操作基本采用的是標(biāo)準(zhǔn)的SQL語句,也未使用存儲(chǔ)過程,于是將原有的數(shù)據(jù)接入層代碼改寫成泛型類,只改了不到一百行代碼,具體的SQL操作語句一句未動(dòng),便實(shí)現(xiàn)了數(shù)據(jù)庫之間的切換。下面簡述C#泛型操作數(shù)據(jù)庫切換實(shí)踐的具體過程:

數(shù)據(jù)庫不是很復(fù)雜,因此我采用了兩個(gè)類:
(1) DataProvider 泛型類
- public class DataProvider﹤ConnType, CmdType﹥
- where ConnType : IDbConnection, new()
- where CmdType : IDbCommand,new ()
- {
- }
提供數(shù)據(jù)庫表的Insert,Update,Select,Delete操作。因?yàn)?IDbCommand能夠由 IDbConnection 獲取,其實(shí)只需要有一個(gè)泛型參數(shù)ConnType 的,不過這樣以來,具體的代碼改動(dòng)比較大,偶就采用了兩個(gè)泛型參數(shù)。
(2)ConnectionPool 泛型類
- public class ConnectionPool﹤T﹥
- where T : IDbConnection,new ()
- {
- }
最開始沒在MySql 5.0 中找到對(duì)數(shù)據(jù)庫連接池的支持,于是自己寫了一個(gè)簡單的數(shù)據(jù)庫連接池。
C# 泛型操作數(shù)據(jù)庫切換的實(shí)現(xiàn):
下面,就是采用 C# 的NB語法――using:
(1)如果使用 MySql 數(shù)據(jù)庫:
- using DataProvider =
- DataProvider﹤MySql.Data.MySqlClient.MySqlConnection,
- MySql.Data.MySqlClient.MySqlCommand﹥;
(2)如果使用 SQLServer 數(shù)據(jù)庫:
- using DataProvider =
- DataProvider﹤System.Data.SqlClient.SqlConnection,
- System.Data.SqlClient.SqlCommand﹥;
這樣一來,其它地方的代碼一句都不用動(dòng)了。
懶惰是程序員的美德。我的一臺(tái)電腦上裝的是 SQLServer 2000數(shù)據(jù)庫,一臺(tái)電腦上裝的是 MySql數(shù)據(jù)庫,我經(jīng)常一會(huì)在這臺(tái)電腦上干活,一會(huì)在另外一臺(tái)電腦上干活,兩個(gè)電腦上的代碼應(yīng)該一致啊。因此,采用預(yù)編譯指令:
- #if MSSQLSERVER
- using System.Data.SqlClient;
- using DataProvider = DataProvider﹤System.Data.SqlClient.SqlConnection, System.Data.SqlClient.SqlCommand﹥;
- #elif MYSQL
- using MySql.Data;
- using DataProvider = DataProvider﹤MySql.Data.MySqlClient.MySqlConnection, MySql.Data.MySqlClient.MySqlCommand﹥;
- #endif
這樣在編譯時(shí)指定條件編譯符號(hào) " MYSQL " 得到的就是MySql版本的代碼,指定條件編譯符號(hào)" MSSQLSERVER ",得到的就是 SQLServer 版本的代碼。
C# 泛型操作數(shù)據(jù)庫切換操作的總結(jié):
(1)理論上來說,采用反射得到的解決方案更完美,不過那樣工期會(huì)更長。
(2)數(shù)據(jù)庫設(shè)計(jì),偶采用的是免費(fèi)軟件 Toad Data Modeler 免費(fèi)版,里面提供了數(shù)據(jù)庫切換功能,切換過去,稍微改動(dòng)改動(dòng)。
(3)這次開發(fā)工具采用的全是開源軟件或者免費(fèi)軟件,都是超級(jí)好用的東東,感覺開發(fā)速度并不比龐大的收費(fèi)軟件慢。用到的工具如下:
IDE:VS 2005 Express (C++版,C#版,Web開發(fā)版),.Net的aspnet命令行編譯工具
版本管理:SVN,小烏龜SVN Client
Shell:Windows Power Shell(這玩意既然出來了,就要充分利用)
UML建模:StarUML(功能強(qiáng)大的開源UML,比偶以前用過的JUDE,ArgoUML強(qiáng)大很多,支持C#)
數(shù)據(jù)庫建模:Toad Data Modeler 免費(fèi)版
數(shù)據(jù)庫管理工具:EMS SQL Manager 2005 lite for MySQL
C# 泛型操作數(shù)據(jù)庫切換實(shí)踐的基本內(nèi)容就向你介紹到這里,希望對(duì)你了解和學(xué)習(xí)C# 泛型操作數(shù)據(jù)庫切換實(shí)踐有所幫助。
【編輯推薦】
- C# 泛型數(shù)組學(xué)習(xí)小結(jié)
- C# 泛型委托學(xué)習(xí)經(jīng)驗(yàn)淺析
- 淺析運(yùn)行庫中的C# 泛型
- C# 泛型方法中反射常用方法淺析
- C# 泛型應(yīng)用中屬性淺析
分享名稱:C#泛型操作數(shù)據(jù)庫切換實(shí)踐
文章來源:http://www.fisionsoft.com.cn/article/cdgjhpg.html


咨詢
建站咨詢
