您的位置:首页 > 数据库

策略模式实现支持多种类数据库的DBHelp(推荐--arvin)

2013-04-18 09:46 381 查看
来自:http://www.cnblogs.com/springyangwc/archive/2013/03/17/2964428.html#2636446

概述

需求

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

设计

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





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

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

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

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

2、 在基本的策略模式中,选择所用具体实现的职责由客户端对象承担,并转给策略模式的Context对象。(这本身没有解除客户端需要选择判断的压力,而策略模式与简单工厂模式结合后,选择具体实现的职责也可以由Context来承担,这就最大化的减轻了客户端的压力。)
DBHelp设计目标,同时支持Sqlite、Oracle 、MySql 、MsSql,类UML图设计如下:





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

?
再创建IDBHelp接口:

?
再创建AbstractDBHelp 抽象类:

?
再创建MSSqlHelp 类:

?
再创建MySqlHelp类

?
再创建OracleHelp类:

?
再创建SQLiteHelp类:

?
仔细观察上面代码,发现每增加一种数据库的支持,我们只需实现几个特有抽象方法就可以了,而调用只需像如下就可以了。

?
欢迎各位参与讨论,如果觉得对你有帮助,请点击


推荐下,万分谢谢.


作者:spring yang

出处:http://www.cnblogs.com/springyangwc/

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐