策略模式实现支持多种类数据库的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),它定义了一系列的算法,并将每一个算法封装起来,而且使它们还可以相互替换。策略模式让算法的变化不会影响到使用算法的客户。
![](http://images.cnitblog.com/blog/243452/201303/17140310-ff3de80747fd4a9ba8a5285efefb9649.gif)
优点:
1、 简化了单元测试,因为每个算法都有自己的类,可以通过自己的接口单独测试。
2、 避免程序中使用多重条件转移语句,使系统更灵活,并易于扩展。
3、 遵守大部分GRASP原则和常用设计原则,高内聚、低偶合。
缺点:
1、 因为每个具体策略类都会产生一个新类,所以会增加系统需要维护的类的数量。
2、 在基本的策略模式中,选择所用具体实现的职责由客户端对象承担,并转给策略模式的Context对象。(这本身没有解除客户端需要选择判断的压力,而策略模式与简单工厂模式结合后,选择具体实现的职责也可以由Context来承担,这就最大化的减轻了客户端的压力。)
DBHelp设计目标,同时支持Sqlite、Oracle 、MySql 、MsSql,类UML图设计如下:
![](http://images.cnitblog.com/blog/243452/201303/17140319-84fe030ccdb445679c0ac9d6ad3ecf55.png)
有了上面的设计图如后,我们先创建Enums:
?
再创建IDBHelp接口:
?
再创建AbstractDBHelp 抽象类:
?
再创建MSSqlHelp 类:
?
再创建MySqlHelp类
?
再创建OracleHelp类:
?
再创建SQLiteHelp类:
?
仔细观察上面代码,发现每增加一种数据库的支持,我们只需实现几个特有抽象方法就可以了,而调用只需像如下就可以了。
?
欢迎各位参与讨论,如果觉得对你有帮助,请点击
![](http://images.cnblogs.com/cnblogs_com/springyangwc/201110/201110111252023406.png)
推荐下,万分谢谢.
作者:spring yang
出处:http://www.cnblogs.com/springyangwc/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
概述
需求
有时我们的系统需要支持多种数据库,如即要支持MSSQL server又要同时支持Oracle database.而如果我们为些实现两套数据库操作的方式,就会不能很好的达到软件设计的目标:高内聚,低偶合。
设计
采取策略模式(Strategy),它定义了一系列的算法,并将每一个算法封装起来,而且使它们还可以相互替换。策略模式让算法的变化不会影响到使用算法的客户。
![](http://images.cnitblog.com/blog/243452/201303/17140310-ff3de80747fd4a9ba8a5285efefb9649.gif)
优点:
1、 简化了单元测试,因为每个算法都有自己的类,可以通过自己的接口单独测试。
2、 避免程序中使用多重条件转移语句,使系统更灵活,并易于扩展。
3、 遵守大部分GRASP原则和常用设计原则,高内聚、低偶合。
缺点:
1、 因为每个具体策略类都会产生一个新类,所以会增加系统需要维护的类的数量。
2、 在基本的策略模式中,选择所用具体实现的职责由客户端对象承担,并转给策略模式的Context对象。(这本身没有解除客户端需要选择判断的压力,而策略模式与简单工厂模式结合后,选择具体实现的职责也可以由Context来承担,这就最大化的减轻了客户端的压力。)
DBHelp设计目标,同时支持Sqlite、Oracle 、MySql 、MsSql,类UML图设计如下:
![](http://images.cnitblog.com/blog/243452/201303/17140319-84fe030ccdb445679c0ac9d6ad3ecf55.png)
有了上面的设计图如后,我们先创建Enums:
?
?
?
?
?
?
?
?
![](http://images.cnblogs.com/cnblogs_com/springyangwc/201110/201110111252023406.png)
推荐下,万分谢谢.
作者:spring yang
出处:http://www.cnblogs.com/springyangwc/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
相关文章推荐
- 策略模式实现支持多种类数据库的DBHelp
- 策略模式实现支持多种类数据库的DBHelp
- 策略模式实现支持多种类数据库的DBHelp
- jdbc连接Oracle数据库实现学生管理系统(用数据库连接池支持多用户操作同一数据库)
- 结合Resumable.js实现在Server端PHP支持的大文件上传、断点续传功能 推荐
- DBCP的数据库连接归还--利用 编程式AOP实现(不推荐)
- 在家看孩子,10分钟生成一个业务管理系统【能支持多数据库,大数据,流程审批,权限控制,即时提醒】,视频讲解详细实现步骤
- [数据库测试]强烈推荐一个python ODBC数据源插件,可支持Oracle,Db2,Mysql,Sql-server以及各种数据库版本,附例子和测试程序
- 优化企业级备份策略,实现无负载数据库备份及监控 推荐
- 使用反射实现多数据库支持
- 【原创】无限分级Repeater递归实现:读取一次数据库,使用LINQ2SQL技术,支持排序&显示隐藏
- 项目实现多数据库支持
- [数据库测试]强烈推荐一个python ODBC数据源插件,可支持Oracle,Db2,Mysql,Sql-server以及各种数据库版本,附例子和测试程序
- 利用日志传送来实现数据库的可用性 推荐
- jb51站长推荐的用js实现的多浏览器支持的图片轮换展示效果ie,firefox
- js实现web套打功能,支持拖动布局,支持按键移动支持打印预览,结果可保存至数据库中
- heartbeat v1 实现 MariaDB数据库的高可用 推荐
- [小蜗牛论断]Sendmail无法真正实现多域名支持 推荐
- 系统好友推荐实现之数据库设计实例
- 强烈推荐一个超酷的跨平台、支持多数据库的数据库管理工具