mysql 数据库dbhelp_策略模式实现支持多种类数据库的DBHelp

概述

需求

有时我们的系统需要支持多种数据库,如即要支持MSSQL server又要同时支持Oracle database.而如果我们为些实现两套数据库操作的方式,就会不能很好的达到软件设计的目标:高内聚,低偶合。

设计

采取策略模式(Strategy),它定义了一系列的算法,并将每一个算法封装起来,而且使它们还可以相互替换。策略模式让算法的变化不会影响到使用算法的客户。

d4baf4eeb53f444151747740137f3e33.gif

优点:

1、 简化了单元测试,因为每个算法都有自己的类,可以通过自己的接口单独测试。

2、 避免程序中使用多重条件转移语句,使系统更灵活,并易于扩展。

3、 遵守大部分GRASP原则和常用设计原则,高内聚、低偶合。

缺点:

1、 因为每个具体策略类都会产生一个新类,所以会增加系统需要维护的类的数量。

2、 在基本的策略模式中,选择所用具体实现的职责由客户端对象承担,并转给策略模式的Context对象。(这本身没有解除客户端需要选择判断的压力,而策略模式与简单工厂模式结合后,选择具体实现的职责也可以由Context来承担,这就最大化的减轻了客户端的压力。)

DBHelp设计目标,同时支持Sqlite、Oracle 、MySql 、MsSql,类UML图设计如下:

44b355e5baef5744ecefb7be5342b7e5.png

有了上面的设计图如后,我们先创建Enums: /********************************************************************************

** Class Name: Enums

** Author: Spring Yang

** Create date: 2013-3-16

** Modify: Spring Yang

** Modify Date: 2013-3-16

** Summary: Enums class

*********************************************************************************/

namespace BlogDBHelp

{

using System;

[Serializable]

public enum SqlSourceType

{

Oracle,

MSSql,

MySql,

SQLite

}

}

再创建IDBHelp接口:

/********************************************************************************

** Class Name: IDBHelp

** Author: Spring Yang

** Create date: 2013-3-16

** Modify: Spring Yang

** Modify Date: 2013-3-16

** Summary: IDBHelp interface

*********************************************************************************/

namespace BlogDBHelp

{

using System.Collections.Generic;

using System.Data;

using System.Data.Common;

public interface IDBHelp

{

///

/// Gets the connection string

///

string ConnectionString { get; set; }

///

/// Gets or sets the max connection count

///

int MaxConnectionCount { get; set; }

///

/// Gets or sets the sql source type

///

SqlSourceType DataSqlSourceType { get; }

///

/// Execute query by stored procedure

///

/// stored procedure

/// DataSet

DataSet ExecuteQuery(string cmdText);

///

/// Execute non query by stored procedure and parameter list

///

/// stored procedure

/// execute count

int ExecuteNonQuery(string cmdText);

///

/// Execute scalar by store procedure

///

/// store procedure

/// return value

object ExecuteScalar(string cmdText);

///

/// Get data base parameter by parameter name and parameter value

///

/// parameter name

/// parameter value

/// sql parameter

DbParameter GetDbParameter(string key, object value);

///

/// Get data base parameter by parameter name and parameter value

/// and parameter direction

///

/// parameter name

/// parameter value

/// parameter direction

/// data base parameter

DbParameter GetDbParameter(string key, object value, ParameterDirection direction);

///

/// Read entity list by store procedure

///

/// entity

/// store procedure

/// entity list

List ReadEntityList(string cmdText) where T : new();

///

/// Get dictionary result by store procedure and parameters and string list

///

/// store procedure

/// string list

/// result list

List> GetDictionaryList(string cmdText,

List stringlist);

///

/// Batch execute ExecuteNonQuery by cmdText list

///

/// cmd text list

/// execute true or not

bool BatchExecuteNonQuery(List cmdList);

}

}

再创建AbstractDBHelp 抽象类:

/********************************************************************************

** Class Name: AbstractDBHelp

** Author: Spring Yang

** Create date: 2013-3-16

** Modify: Spring Yang

** Modify Date

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值