概述
需求
有时我们的系统需要支持多种数据库,如即要支持MSSQL server又要同时支持Oracle database.而如果我们为些实现两套数据库操作的方式,就会不能很好的达到软件设计的目标:高内聚,低偶合。
设计
采取策略模式(Strategy),它定义了一系列的算法,并将每一个算法封装起来,而且使它们还可以相互替换。策略模式让算法的变化不会影响到使用算法的客户。
优点:
1、 简化了单元测试,因为每个算法都有自己的类,可以通过自己的接口单独测试。
2、 避免程序中使用多重条件转移语句,使系统更灵活,并易于扩展。
3、 遵守大部分GRASP原则和常用设计原则,高内聚、低偶合。
缺点:
1、 因为每个具体策略类都会产生一个新类,所以会增加系统需要维护的类的数量。
2、 在基本的策略模式中,选择所用具体实现的职责由客户端对象承担,并转给策略模式的Context对象。(这本身没有解除客户端需要选择判断的压力,而策略模式与简单工厂模式结合后,选择具体实现的职责也可以由Context来承担,这就最大化的减轻了客户端的压力。)
DBHelp设计目标,同时支持Sqlite、Oracle 、MySql 、MsSql,类UML图设计如下:
有了上面的设计图如后,我们先创建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