亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C#利用IDbCommand實(shí)現(xiàn)通用數(shù)據(jù)庫(kù)腳本執(zhí)行程序

 更新時(shí)間:2024年04月29日 11:11:34   作者:初九之潛龍勿用  
在.net 應(yīng)用中,在數(shù)據(jù)庫(kù)中執(zhí)行腳本程序是經(jīng)常用到的功能,如數(shù)據(jù)操作(新增、修改、刪除等),執(zhí)行一個(gè)存儲(chǔ)過(guò)程等,本文將介紹如何通過(guò)利用IDbCommand 實(shí)現(xiàn)通用數(shù)據(jù)庫(kù)腳本執(zhí)行程序,感興趣的朋友可以參考下

關(guān)于 ExecuteNonQuery

在.net 應(yīng)用中,在數(shù)據(jù)庫(kù)中執(zhí)行腳本程序是經(jīng)常用到的功能,如數(shù)據(jù)操作(新增、修改、刪除等),執(zhí)行一個(gè)存儲(chǔ)過(guò)程等,實(shí)現(xiàn)的核心方法需要執(zhí)行 Command 對(duì)象的ExecuteNonQuery方法。該方法對(duì)數(shù)據(jù)庫(kù)連接執(zhí)行 Transact-SQL 語(yǔ)句并返回受影響的行數(shù)。

生成數(shù)據(jù)集對(duì)象需要利用 ADO.NET 中的數(shù)據(jù)提供者對(duì)象包括IDbConnection、IDbCommand、IDbDataParameter等,如何使用這些對(duì)象請(qǐng)參考這篇文章:C#實(shí)現(xiàn)IDbConnection/IDbCommand等相關(guān)通用數(shù)據(jù)接口_C#教程_腳本之家 (jb51.net)

本文將介紹如何通過(guò)利用IDbCommand 實(shí)現(xiàn)通用數(shù)據(jù)庫(kù)腳本執(zhí)行程序。

數(shù)據(jù)庫(kù)腳本程序的執(zhí)行流程

首先需要?jiǎng)?chuàng)建連接對(duì)象,成功后下達(dá)符合對(duì)應(yīng)數(shù)據(jù)庫(kù)規(guī)范的命令指令,該指令可能包括需要的參數(shù)對(duì)象(需要定義名稱和賦值等操作),通過(guò) IDbCommand 命令接口對(duì)象執(zhí)行,大體流程如下圖:

范例運(yùn)行環(huán)境

操作系統(tǒng): Windows Server 2019 DataCenter

.net版本: .netFramework4.7.1 或以上

開發(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)方法前請(qǐng)引用如下代碼:

using System.Data;
using System.Data.SqlClient;
using System.Data.OracleClient;
using Dm;
using System.Collections;

DAL類

創(chuàng)建一個(gè) DAL 數(shù)據(jù)操作類,該類設(shè)計(jì)如下:

序號(hào)成員類型說(shuō)明
1public string ConnKeyString=""
        
屬性訪問(wèn)在ConfigurationSettings.AppSettings[ConnKeyString]中存儲(chǔ)的數(shù)據(jù)連接串,該關(guān)鍵字為優(yōu)先選項(xiàng),如果為空則訪問(wèn) ConnString 直接連接串
2public string ConnString=""屬性IdbConnection對(duì)象的連接串,該屬性僅到ConnKeyString為空時(shí)試圖訪問(wèn)
3public string DbServerType=""
       
屬性目前支持 "oracle"、 "dm8",其它字符串均視為 MS SQL Server
4public string ErrorMessage=""
        
        
        
屬性當(dāng)執(zhí)行腳本命令發(fā)生錯(cuò)誤時(shí)捕捉到的錯(cuò)誤信息
5public int RowsCount=0屬性當(dāng)執(zhí)行腳本命令成功后的影響行數(shù),默認(rèn)值為0
6public int ErrorNum=0屬性當(dāng)執(zhí)行腳本命令失敗時(shí),返回?cái)?shù)據(jù)庫(kù)提供的錯(cuò)誤號(hào)
7public void ExecDbScripts(string _sql,ArrayList paras,CommandType ct)方法ExecDbScripts 方法用于執(zhí)行數(shù)據(jù)庫(kù)腳本

ExecDbScripts 方法無(wú)返回值,均通過(guò)設(shè)置 ErrorMessage、RowsCount、ErrorNum屬性實(shí)現(xiàn),其參數(shù)說(shuō)明見下表:

序號(hào)參數(shù)名類型說(shuō)明
2_sqlstring要執(zhí)行的SQL語(yǔ)句命令行
3parasArrayList

要賦值的參數(shù)對(duì)象,逐個(gè)添加到ArrayList里,請(qǐng)注意參數(shù)為實(shí)體數(shù)據(jù)參數(shù)對(duì)象,如 MS SQL Server ,請(qǐng)傳遞如下代碼:

ArrayList.Add(new SqlParameter("參數(shù)名",參數(shù)值)); 

ctCommandType

System.Data.CommandType 枚舉,可包括:

StoredProcedure(存儲(chǔ)過(guò)程)
TableDirect(直接表查詢)
Text(文本查詢)該值為默認(rèn)值

有關(guān) CommandType 的更多資料請(qǐng)參考如下鏈接:CommandType 枚舉 (System.Data) | Microsoft Learn

實(shí)現(xiàn)代碼

DAL類完整的實(shí)現(xiàn)代碼如下:

public class CODAL
{
		public string ConnKeyString="JaneConnection";
		public string ConnString="";
		public string DbServerType= ConfigurationSettings.AppSettings["DbServerType"];
        public string ErrorMessage="";
		public int RowsCount=0;
		public int ErrorNum=0;
 
		public void ExecDbScripts(string _sql,ArrayList paras,CommandType ct)
		{
			string strConn =ConfigurationSettings.AppSettings[ConnKeyString];
			if(ConnString!="")
			{
				strConn=ConnString;
			}
			System.Data.IDbConnection Conn=GetConnection(DbServerType,strConn);
			System.Data.IDbCommand Cmd=GetCommand(DbServerType,_sql,paras,Conn);
			Cmd.CommandType=ct;
			Cmd.CommandTimeout=CommandTimeOut;
			try
			{
				Conn.Open();
				int i=Cmd.ExecuteNonQuery();
				RowsCount=i;
			}
			catch (Exception e)
			{
				if (e.GetType() ==typeof(System.Data.SqlClient.SqlException))
				{
					int errnumber = ((System.Data.SqlClient.SqlException)e).Number;
					ErrorNum = errnumber;
				}else if (e.GetType() == typeof(System.Data.OracleClient.OracleException))
                {
                    int errnumber = ((System.Data.OracleClient.OracleException)e).Code;
                    ErrorNum = errnumber;
                }
                else if (e.GetType() == typeof(DmException))
                {
                    int errnumber = ((DmException)e).Number;
                    ErrorNum = errnumber;
                }
				ErrorMessage=rv[1];
				Cmd.Parameters.Clear();
			}
			finally
			{
				if(Conn.State==ConnectionState.Open)
				{
					Conn.Close();
				}
			}
		}
		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;
 
		}
		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;
		}
        public System.Data.IDbDataParameter GetParameter(string dbservertype,object paras)
		{
			IDbDataParameter para = null;
			switch (dbservertype.ToLower())
			{
 
				case "oracle": para =(OracleParameter)paras; 
					break;
                case "dm8":
                    para =  (DmParameter)paras;
                    break;
                default: para =(SqlParameter)paras; break;
			}
			return para;
		}
 
}

小結(jié)

到此這篇關(guān)于C#利用IDbCommand實(shí)現(xiàn)通用數(shù)據(jù)庫(kù)腳本執(zhí)行程序的文章就介紹到這了,更多相關(guān)C# IDbCommand數(shù)據(jù)庫(kù)腳本內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論