0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

DAO设计模式的优缺点及实现方法

电子设计 作者:电子设计 2018-11-21 07:57 次阅读

1 引言

目前,在Internet/Intranet环境中,企业级的应用软件系统大多采用3层应用框架:表示层、业务逻辑层和数据层(图1)。业务逻辑层代码中混杂各种数据库调用语句,严重影响系统的可扩展性、可复用性和可维护性。采用设计模式可有效解决这些难点,从而简单方便地复用成功的设计和体系结构。通过采用设计模式,能大大提高系统的可扩展性、可重用性和可维护性,并能降低系统开发难度,提高开发效率。设计模式已成为当前乃至今后软件工程研究领域的一大热点,并被认为是继OOP技术之后的又一重大突破。充分考虑系统的可扩展性,可复用性,可维护性,从软件设计模式角度提出改进方法,并给出研究实例。

DAO设计模式的优缺点及实现方法

2 设计模式

每一个模式描述一个在不断重复发生的问题,以及该问题解决方案的核心。这样就能多次使用该方案而不必重复劳动。设计模式是面向对象软件设计过程中记录的知识和经验,用一系列类结构和对象来具体描述其含义。设计模式通过复用面向对象设计的解决方案,从而更加简单方便地复用成功的设计和体系结构,将已证实的技术表述成设计模式也会使新系统开发者更加容易理解其设计思路。设计模式可帮助设计者做出有利于系统复用选择,避免损害系统复用性,通过提供一个显式类和对象作用关系及它们之间潜在联系说明规范,设计模式甚至能够提高已有系统的文档管理和系统维护的有效性。设计模式确定所包含的类和实例及其角色、协作方式、职责分配。通过刻画部件静态和动态结构及其之间的合作关系,设计模式成功应用于解决商业数据处理、电子通信、图形用户界面、数据库、分布式通信软件等软件构造中。

3 改进的4层架构开发模型

基于上述分析,为提高软件的开发效率,这里从设计模式角度出发,提出把业务逻辑层进一步分出一层,单独形成一个数据接口层。数据接口层屏蔽各种底层数据库之间的差异,负责与底层数据库之间的连接。形成4层软件体系结构框架,从上到下依次是:表示层、业务逻辑层、数据接口层、数据层,如图2所示。表示层是应用软件进行人机交互的接口;业务逻辑层负责处理用户的业务请求;数据接口层负责与底层数据库之间的交互;数据层则负责存储数据。

3.1 DAO设计模式

业务对象只应该关注业务逻辑,不应该关心数据存取的细节。数据访问对象必须实现特定的持久化策略(如,基于JDBC或HIBERNATEH的持久化逻辑), 这样就抽出来了DAO层,作为数据源层,而之上的Domain Model层与之通讯而已,如果将那些实现了数据访问操作的所有细节都放入高层Domain model(领域模型)的话,系统的结构一定层次上来说就变得有些混乱。低级别的数据访问逻辑与高级别的业务逻辑分离,用一个DAO接口隐藏持久化操作的 细节,这样使用的最终目的就是让业务对象无需知道底层的持久化技术知识,这是标准 j2ee 设计模式之一。一个典型的的DAO组成:DAO工厂类,DAO接口,实现DAO接口的具体类(每个DAO实例负责一个主要域对象或实体),VO(Value Object)。如果一个DAO工厂只为一个数据库的实现(现在只考虑这种情况)而创建很多的DAO的时候,实现该策略时,我们考虑采用工厂方法设计模式。

DAO设计模式的优点:

(1)DAO模式抽象出数据访问方式,业务逻辑层访问数据源时完全感觉不到数据源的存在。软件工厂中有一条很重要的法则:一个对象对其他对象的了解越少越好,了解越少就意味着依赖越少,可复用性越高。

(2)DAO将数据访问集中在独立的一层,因为所有的数据访问都由DAO代理,这层独立的DAO将数据访问的实现和系统的其余部分剥离,将数据访问集中,使得系统更具可维护性。

(3)DAO降低了业务逻辑层的复杂度。DAO管理复杂的数据访问,从而简化了业务逻辑层。所有与数据访问的实现有关的代码都不写在业务逻辑层里,业务逻辑层可集中处理业务逻辑,提高了代码的可读性和生产率。

(4)DAO有助于提升系统的可移植性。DAO模式通过将数据访问划分为抽象层和实现层,分离数据使用和数据访问的实现细节。这意味着业务层与数据访问的底层细节无关,也就是说,可以在保持上层机构不变的情况下,通过切换底层实现来修改数据访问的具体机制,提高了系统的可复用性。

(5)DAO组件依赖于数据库系统,提供数据库访问接口,只要数据库没有重构,DAO层通常无须改写。DAO层透明地分离数据库与业务逻辑层,业务逻辑层专注于业务逻辑的实现,而无须关心持久层访问的实现。

(6)DAO模式的进一步改良。由于DAO层已实现所有的数据访问,业务逻辑层只需调用DAO接口,因此业务逻辑层要使用Facade模式包装DAO。为实现跨数据库平台移植,支持不同数据访问机制之间的可配置切换,需在DAO层引入Factorv模式、Proxy模式和Strategy模式,则可方便地在不同数据存储方式间切换。然而,采用DAO模式,系统在请求数据端和数据服务端之间增加一层,增加了系统的复杂度;新增加的一层需要额外的设计与实现,增加了工作量;还需引入工厂甚至抽象工厂,增加了设计的复杂度。总的来说,DAO将数据持久层与业务逻辑层分离,提高了软件的可扩展性,可维护性和可复用性。

3.2 DAO实现

DAO对象也是。Java对象,只是它们提供数据库访问的能力。数据库的访问可归纳为创建(Create)、查询(Read)、更新(Update)、删除(Delete)4种基本操作,即常说的CRUD操作。DAO模式通常与工厂模式一起使用,建议面向接口编程,为每个DAO实现类编写接口,DAO调用者使用接口,而不是具体的实现类。当然,DAO对象需要值对象来传值,值对象就是普通的JavaBean。以下是一个DAO的示例。图3为数据访问对象设计模式的参与对象和它们之间的调用关系。图4为该示例的详细类图。

DAO设计模式的优缺点及实现方法

该DAO示例包含文件:DAO接口类、DAO接口实现类、DaoFactory类、PersonBean类、DBConn类、Test类。接口里定义 DAO对象必须提供方法,PersonBean是一个普通的JavaBean,DAO对象的实现类为接口的全部方法提供实现。程序中还用到工具类 DBConn,该工具类主要用于获得数据库连接,通过连接获得Statement对象,并提供释放Statement对象、关闭连接的方法。

程序将DBConn对象设计成单态模式。至此,完整的DAO实例编写完成。程序主要提供3个组件:传值的JavaBean类,DAO对象的接口,DAO对象的实现类,实现类包括所用的工具类。DAO模式通常与工厂模式相结合,DAO工厂负责产生DAO实例。两者结合可更好地实现业务组件与持久层组件的解耦。业务组件只需获取DAO工厂实例,然后由DAO工厂实例负责产生DAO组件。业务组件则面向DAO接口编程,无须关心DAO的具体实现。

4 结束语

本文通过分析传统3层软件体系结构的优缺点,从软件模式角度出发,对其进行改进,提出4层开发模型,提高了系统的可扩展性、可复用性、可维护性,并给出一个具体应用实例实现DAO设计模式。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 软件
    +关注

    关注

    69

    文章

    4682

    浏览量

    87066
  • Internet
    +关注

    关注

    0

    文章

    400

    浏览量

    36796
收藏 人收藏

    评论

    相关推荐

    滚动模式和XY模式如何使用呢?各个模式有什么样的优缺点

    示波器观察波形有三种视图模式,分别是YT模式、滚动模式、XY模式,虽然多数情况使用YT模式即可,但滚动
    的头像 发表于 10-16 09:12 1.4w次阅读

    LED电源恒流驱动与恒压驱动模式优缺点

    ,各自也有相应的优势和缺陷。本文今天将会就这两种LED电源的驱动模式来为各位工程师们进行一次优缺点盘点。 首先来看LED电源的恒压驱动模式,这种驱动方式能够在负载端对输出电压进行采样,线性稳压电源反馈回路
    发表于 10-09 14:18

    SASS和LESS等优缺点对比及使用方法

    SASS和LESS等优缺点对比,使用方法总结 (笔记大全)
    发表于 05-21 14:09

    binlog有什么意义/工作模式/优缺点

      Linux运维是现下较为火热的职业岗位之一。学习Linux技术的人越来越多。Linux运维学习过程中,binlog有什么意义?binlog有哪些工作模式?都有哪些优缺点?binlog有哪些企业
    发表于 01-29 17:24

    DSP的并行互连方法有哪些,其各自的优缺点是什么?

    DSP的并行互连方法有哪些,其各自的优缺点是什么?如何利用TMS320C6x的HPI组成多DSP互联并行系统?如何利用ADSP2106x的Link口组成多DSP互连并行系统?
    发表于 04-08 06:41

    开关模式电源的电流检测方法优缺点有哪些

    开关模式电源的电流检测技术有何优点?开关模式电源的电流检测方法有哪几种?分别有什么优缺点
    发表于 08-17 09:09

    步进电机有哪些优缺点?是什么工作原理?操作模式有哪些?

    步进电机的特点是什么?有哪些优缺点?步进电机有哪些类型?步进电机是什么工作原理?步进电机的操作模式有哪几种?
    发表于 09-23 08:33

    什么是OFDM?有什么优缺点

    什么是OFDM?有什么优缺点?OFDM中降低PAPR的方法有哪些?
    发表于 10-09 07:41

    受限单极PWM模式有哪些优缺点

    双极PWM调制模式是什么意思?单极PWM调制模式是什么意思?受限单极PWM模式有哪些优缺点
    发表于 10-11 07:03

    什么是IoC?具有哪些优缺点

    什么是IoC?具有哪些优缺点
    发表于 10-21 09:33

    LwIP的优缺点是什么

    目录2.1 LwIP 的优缺点2.2 LwIP 的文件说明2.2.1 如何获取 LwIP 源码文件2.2.2 LwIP 文件说明2.3 使用 vscode 查看源码2.3.1 查看文件中的符号列表
    发表于 01-20 06:25

    矩阵按键的扫描方法有何优缺点

    矩阵按键需要用多少个单片机引脚进行连接呢?矩阵按键的扫描方法有何优缺点呢?具体怎样去实现
    发表于 02-23 06:11

    电流模式开关稳压器的优缺点及应用

    优缺点。电流模式稳压器解析图1显示电流模式稳压器的基本工作原理。这里,不止将反馈电压与内部基准电压进行比较,还将其与生成电源开关所需的PWM信号所用的锯齿形电压斜坡进行比较。在电压模式
    发表于 10-09 10:18

    超级电容电池的优缺点_自制超级电容电池的方法

    本文主要介绍了超级电容电池的优缺点及制作方法
    发表于 08-03 10:16 2.3w次阅读
    超级电容电池的<b class='flag-5'>优缺点</b>_自制超级电容电池的<b class='flag-5'>方法</b>

    反激变换器DCM与CCM模式优缺点

    反激变换器DCM与CCM模式优缺点(罗马仕电源技术偏执狂价格)-反激变换器DCM与CCM模式优缺点             
    发表于 08-31 15:18 75次下载
    反激变换器DCM与CCM<b class='flag-5'>模式</b>的<b class='flag-5'>优缺点</b>