C#實(shí)現(xiàn)IDbConnection/IDbCommand等相關(guān)通用數(shù)據(jù)接口
關(guān)于數(shù)據(jù)接口
在.net 應(yīng)用中,與數(shù)據(jù)庫(kù)進(jìn)行連接、訪問(wèn)和執(zhí)行經(jīng)常會(huì)用到數(shù)據(jù)接口的相關(guān)對(duì)象,如下:
1、 Connection
表示一個(gè)到數(shù)據(jù)庫(kù)的打開(kāi)的連接,是連接數(shù)據(jù)必不可少的對(duì)象。
2、 Command
命令對(duì)象,表示要對(duì)數(shù)據(jù)源連接執(zhí)行的 SQL 語(yǔ)句或存儲(chǔ)過(guò)程,以獲取返回結(jié)果或執(zhí)行返回值。
3、 DataParameter
用于表示Command命令對(duì)象需要的參數(shù)設(shè)置,雖然這是一個(gè)可選項(xiàng),但在實(shí)際的應(yīng)用中幾乎都會(huì)使用到
ADO.NET 中的數(shù)據(jù)提供者對(duì)象提供了IDbConnection、IDbCommand、IDbDataParameter等通用數(shù)據(jù)接口,本文將利用這些對(duì)象實(shí)現(xiàn)一個(gè)通用方法以訪問(wèn)和操作數(shù)據(jù)庫(kù)內(nèi)容。
對(duì)象執(zhí)行流程
首先需要?jiǎng)?chuàng)建連接對(duì)象,成功后下達(dá)符合對(duì)應(yīng)數(shù)據(jù)庫(kù)規(guī)范的命令指令,該指令可能包括需要的參數(shù)對(duì)象(需要定義名稱和賦值等操作),大體流程如下圖:
范例運(yùn)行環(huán)境
操作系統(tǒng): Windows Server 2019 DataCenter
.net版本: .netFramework4.7.1 或以上
開(kāi)發(fā)工具:VS2019 C#
數(shù)據(jù)庫(kù):在這里我們以支持 Oracle 9i、MS SQL Server 2016、國(guó)產(chǎn)達(dá)夢(mèng)數(shù)據(jù) 8 為例
設(shè)計(jì)與實(shí)現(xiàn)
引用
在實(shí)現(xiàn)方法前請(qǐng)引用如下代碼:
using System.Data; using System.Data.SqlClient; using System.Data.OracleClient; using Dm; using System.Collections;
GetConnection方法
GetConnection 方法返回 System.Data.IDbConnection 對(duì)象,其參數(shù)說(shuō)明見(jiàn)下表:
序號(hào) | 參數(shù)名 | 類型 | 說(shuō)明 |
---|---|---|---|
1 | DbServerType | string | 目前支持 "oracle"、 "dm8",其它字符串均視為 MS SQL Server |
2 | ConnectionString | string | 對(duì)應(yīng)數(shù)據(jù)庫(kù)的連接字符串 |
實(shí)現(xiàn)代碼如下:
public System.Data.IDbConnection GetConnection(string DbServerType,string ConnectionString) { IDbConnection con = null; switch (DbServerType.ToLower()) { case "oracle": con = new OracleConnection(ConnectionString);break; case "dm8": con = new DmConnection(ConnectionString); break; default: con = new SqlConnection(ConnectionString); break; } return con; }
GetCommand方法
GetCommand 方法返回 System.Data.IDbCommand 對(duì)象,其參數(shù)說(shuō)明見(jiàn)下表:
序號(hào) | 參數(shù)名 | 類型 | 說(shuō)明 |
---|---|---|---|
1 | dbServerType | string | 目前支持 "oracle"、 "dm8",其它字符串均視為 MS SQL Server |
2 | cmdText | string | 要執(zhí)行的SQL語(yǔ)句命令行 |
3 | paras | ArrayList | 要賦值的參數(shù)對(duì)象,逐個(gè)添加到ArrayList里,請(qǐng)注意參數(shù)為實(shí)體數(shù)據(jù)參數(shù)對(duì)象,如 MS SQL Server ,請(qǐng)傳遞如下代碼: ArrayList.Add(new SqlParameter("參數(shù)名",參數(shù)值)); |
4 | con | IDbConnection | 要傳遞的Connection對(duì)象,可能過(guò)前面所述的GetConnection方法獲取 |
實(shí)現(xiàn)代碼如下:
public IDbCommand GetCommand(string dbservertype,string cmdText,ArrayList paras,IDbConnection con) { IDbCommand cmd = null; switch (dbservertype.ToLower()) { case "oracle": cmd = new OracleCommand(cmdText,(OracleConnection)con); break; case "dm8": cmd = new DmCommand(cmdText, (DmConnection)con); break; default: cmd = new SqlCommand(cmdText,(SqlConnection)con); break; } if(paras!=null) { for(int i=0;i<paras.Count;i++) { cmd.Parameters.Add(GetParameter(dbservertype,paras[i])); } } return cmd; }
請(qǐng)注意,代碼中的 GetParameter 方法我們將后續(xù)做介紹。
GetParameter方法
GetParameter 方法返回 System.Data.IDbDataParameter 對(duì)象,其參數(shù)說(shuō)明見(jiàn)下表:
序號(hào) | 參數(shù)名 | 類型 | 說(shuō)明 |
---|---|---|---|
1 | dbServerType | string | 目前支持 "oracle"、 "dm8",其它字符串均視為 MS SQL Server |
2 | para | object | 傳遞的單一參數(shù)對(duì)象 |
實(shí)現(xiàn)代碼如下:
public System.Data.IDbDataParameter GetParameter(string dbservertype,object para) { IDbDataParameter pa = null; switch (dbservertype.ToLower()) { case "oracle": pa =(OracleParameter)para; break; case "dm8": para = (DmParameter)pa; break; default: para =(SqlParameter)pa; break; } return pa; }
小結(jié)
到此這篇關(guān)于C#實(shí)現(xiàn)IDbConnection/IDbCommand等相關(guān)通用數(shù)據(jù)接口的文章就介紹到這了,更多相關(guān)C#實(shí)現(xiàn)IDbConnection/IDbCommand接口內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
詳解C#如何將枚舉以下拉數(shù)據(jù)源的形式返回給前端
這篇文章主要為大家詳細(xì)介紹了C#如何實(shí)現(xiàn)將枚舉以下拉數(shù)據(jù)源的形式返回給前端,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起了解一下2023-06-06C#根據(jù)反射和特性實(shí)現(xiàn)ORM映射實(shí)例分析
這篇文章主要介紹了C#根據(jù)反射和特性實(shí)現(xiàn)ORM映射的方法,實(shí)例分析了反射的原理、特性與ORM的實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-04-04C#使用Ado.Net更新和添加數(shù)據(jù)到Excel表格的方法
這篇文章主要介紹了C#使用Ado.Net更新和添加數(shù)據(jù)到Excel表格的方法,較為詳細(xì)的分析了OLEDB的原理與使用技巧,可實(shí)現(xiàn)較為方便的操作Excel數(shù)據(jù),需要的朋友可以參考下2015-04-04asp.net(C#)清除全部Session與單個(gè)Session的方法
下面小編就為大家?guī)?lái)一篇asp.net(C#)清除全部Session與單個(gè)Session的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-12-12C#實(shí)現(xiàn)掃描局域網(wǎng)內(nèi)的所有IP和端口
這篇文章主要為大家詳細(xì)介紹了如何利用C#實(shí)現(xiàn)掃描局域網(wǎng)內(nèi)的所有IP和端口的功能,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)C#有一定的幫助,感興趣的小伙伴可以跟隨小編一起了解一下2022-12-12