用工厂模式开发多数据库连接类

用工厂模式开发多数据库连接类,是工厂模式最好的应用方式,也是很多初级使用设计模式的程序员都会涉及到的,下面是具体代码:
A、创建一个类库,里面有如下这些类
一、设计一个抽象类
using  System;
using  System.Collections.Generic;
using  System.Text;
using  System.Data;
using  System.Configuration;

// 工厂模式连接数据库
namespace  DBAccess
{
    
//数据连接的工厂模式抽象类
    public abstract class DBabstract
    
{
        
//构造函数
        public DBabstract()
        

        }


        
//打开一个连接
        public abstract void Open();

        
//关闭一个连接
        public abstract void Close();

        
//数据读取的公共数
        public abstract void PublicClass(string procname, object[] parmas);

        
//执行无返回DataSet的函数
        public abstract string Execsql(string procname, object[] parmas);

        
//执行有返回DataSet的函数
        public abstract DataSet ExecSqlReturnDataSet(string tablename, string procname, object[] parmas);

    }

}

二、定义一个Oracle连接类
using  System;
using  System.Collections.Generic;
using  System.Text;
using  System.Data;
using  System.Data.OracleClient;
using  System.Configuration;

// 工厂模式连接数据库中的ORACLE数据库连接
namespace  DBAccess
{
    
//数据连接的工厂模式ORACLE连接类
    internal class DBOracle : DBabstract
    
{
        
private OracleConnection conn = null;  //数据连接
        private OracleCommand cmd = null;      //连接命令

        
//构造函数
        public DBOracle(string constring)
        
{
            
this.conn = new OracleConnection(constring);
        }


        
//打开一个连接
        public override void Open()
        
{
            
if (this.conn != null && this.conn.State == ConnectionState.Closed)
            
{
                
this.conn.Open();
            }

        }


        
//关闭一个连接
        public override void Close()
        
{
            
if (this.conn != null && this.conn.State == ConnectionState.Open)
            
{
                
this.conn.Close();
  • 0
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值