前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >C#实现 IDbConnection / IDbCommand 等相关通用数据接口

C#实现 IDbConnection / IDbCommand 等相关通用数据接口

作者头像
初九之潜龙勿用
发布2024-06-20 13:24:26
780
发布2024-06-20 13:24:26
举报
文章被收录于专栏:技术文章

关于数据接口

在.net 应用中,与数据库进行连接、访问和执行经常会用到数据接口的相关对象,如下:

1、 Connection

表示一个到数据库的打开的连接,是连接数据必不可少的对象。

2、 Command

命令对象,表示要对数据源连接执行的 SQL 语句或存储过程,以获取返回结果或执行返回值。

3、 DataParameter

用于表示Command命令对象需要的参数设置,虽然这是一个可选项,但在实际的应用中几乎都会使用到

ADO.NET 中的数据提供者对象提供了IDbConnection、IDbCommand、IDbDataParameter等通用数据接口,本文将利用这些对象实现一个通用方法以访问和操作数据库内容。

对象执行流程

首先需要创建连接对象,成功后下达符合对应数据库规范的命令指令,该指令可能包括需要的参数对象(需要定义名称和赋值等操作),大体流程如下图:

范例运行环境

操作系统: Windows Server 2019 DataCenter

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

开发工具:VS2019 C#

数据库:在这里我们以支持 Oracle 9i、MS SQL Server 2016、国产达梦数据 8 为例

设计与实现

引用

在实现方法前请引用如下代码:

代码语言:javascript
复制
using System.Data;
using System.Data.SqlClient;
using System.Data.OracleClient;
using Dm;
using System.Collections;
GetConnection方法

GetConnection 方法返回 System.Data.IDbConnection 对象,其参数说明见下表:

序号

参数名

类型

说明

1

DbServerType

string

目前支持 "oracle"、 "dm8",其它字符串均视为 MS SQL Server

2

ConnectionString

string

对应数据库的连接字符串

实现代码如下:

代码语言:javascript
复制
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 对象,其参数说明见下表:

序号

参数名

类型

说明

1

dbServerType

string

目前支持 "oracle"、 "dm8",其它字符串均视为 MS SQL Server

2

cmdText

string

要执行的SQL语句命令行

3

paras

ArrayList

要赋值的参数对象,逐个添加到ArrayList里,请注意参数为实体数据参数对象,如 MS SQL Server ,请传递如下代码: ArrayList.Add(new SqlParameter("参数名",参数值));

4

con

IDbConnection

要传递的Connection对象,可能过前面所述的GetConnection方法获取

实现代码如下:

代码语言:javascript
复制
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;
		}

请注意,代码中的 GetParameter 方法我们将后续做介绍。

GetParameter方法

GetParameter 方法返回 System.Data.IDbDataParameter 对象,其参数说明见下表:

序号

参数名

类型

说明

1

dbServerType

string

目前支持 "oracle"、 "dm8",其它字符串均视为 MS SQL Server

2

para

object

传递的单一参数对象

实现代码如下:

代码语言:javascript
复制
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;
}

小结

范例中所需数据库驱动链接库,请下载我的资源:

qa​​​​​​​https://download.csdn.net/download/michaelline/89235824

更多关于数据接口对象请参考如下链接:

https://learn.microsoft.com/zh-cn/previous-versions/sql/sql-server-2008-r2/ms159940(v=sql.105)

https://learn.microsoft.com/zh-cn/previous-versions/sql/sql-server-2008-r2/ms159923(v=sql.105)

https://learn.microsoft.com/zh-cn/dotnet/api/system.data.idbdataparameter?view=net-8.0&redirectedfrom=MSDN

后续我们将继续介绍如何利用通用接口方法执行数据库内容的操作,感谢您的阅读,希望本文能够对您有所帮助。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-06-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 对象执行流程
  • 范例运行环境
  • 设计与实现
    • 引用
      • GetConnection方法
        • GetCommand方法
          • GetParameter方法
          • 小结
          相关产品与服务
          数据库
          云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档