实体类(VO,DO,DTO,PO)的划分 深碍√TFBOYSˉ_ 2022-10-20 13:52 285阅读 0赞 常常会接触到VO,DO,DTO的概念,本文从领域建模中的实体划分和项目中的实际应用状况两个角度,对这几个概念进行简析。html 得出的主要结论是:在项目应用中,VO对应于页面上须要显示的数据(表单),DO对应于[数据库][Link 1]中存储的数据(数据表),DTO对应于除两者以外须要进行传递的数据。java 1、实体类mysql 百度百科中对于实体类的定义以下:算法 实体类的主要职责是存储和管理系统内部的信息,它也能够有行为,甚至很复杂的行为,但这些行为必须与它所表明的实体对象密切相关。sql 根据以上定义,咱们能够了解到,实体类有两方面内容,存储数据和执行数据自己相关的操做。这两方面内容对应到实现上,最简单的实体类是POJO类,含有属性及属性对应的set和get方法,实体类常见的方法还有用于输出自身数据的toString方法。数据库 [![64bfb689d48271f370372116e606bbc5.png][]][64bfb689d48271f370372116e606bbc5.png 1] 2、领域模型中的实体类设计模式 领域模型中的实体类分为四种类型:VO、DTO、DO、PO,各类实体类用于不一样业务层次间的交互,并会在层次内实现实体类之间的转化。网络 业务分层为:视图层(VIEW+ACTION),服务层(SERVICE),持久层(DAO)数据结构 相应各层间实体的传递以下图:架构 ![56c666d762dac330319a45ad3cd3d54d.png][] 项目中咱们并无严格遵循这种传递关系,但这种和业务层次的关联对咱们理解各实体类的做用是有帮助的。(咱们没有接触到PO的缘由,我理解为ORM对PO进行了封装) 如下是资料的原文,上图是基于此绘制的: **概念:** **VO(View Object):**视图对象,用于展现层,它的做用是把某个指定页面(或组件)的全部数据封装起来。 **DTO(Data Transfer Object):**数据传输对象,这个概念来源于J2EE的设计模式,原来的目的是为了EJB的分布式应用提供粗粒度的数据实体,以减小分布式调用的次数,从而提升分布式调用的性能和下降网络负载,但在这里,我泛指用于展现层与服务层之间的数据传输对象。 **DO(Domain Object):**领域对象,就是从现实世界中抽象出来的有形或无形的业务实体。 **PO(Persistent Object):**持久化对象,它跟持久层(一般是关系型数据库)的[数据结构][Link 2]造成一一对应的映射关系,若是持久层是关系型数据库,那么,数据表中的每一个字段(或若干个)就对应PO的一个(或若干个)属性。 **模型:** 下面以一个时序图创建简单模型来描述上述对象在三层[架构][Link 3]应用中的位置 l 用户发出请求(多是填写表单),表单的数据在展现层被匹配为VO。 l 展现层把VO转换为服务层对应方法所要求的DTO,传送给服务层。 l 服务层首先根据DTO的数据构造(或重建)一个DO,调用DO的业务方法完成具体业务。 l 服务层把DO转换为持久层对应的PO(可使用ORM工具,也能够不用),调用持久层的持久化方法,把PO传递给它,完成持久化操做。 l 对于一个逆向操做,如读取数据,也是用相似的方式转换和传递,略。 3、项目中的实体类 项目中常见的实体类有VO,DO和DTO,命名规则也常是以相应字符串结尾,如\*VO.[Java][]。可是DTO不老是遵循这个规则,而一般与他的用途有关,如写成\*Query.java,表示存储了一个查询条件。项目中实体类出现的业务层次也没有这么严格,例如咱们能够在视图层就组装一个DO,也能够将一个VO从持久层传出来,因此与业务分层相关联的划分方法显得有些冗余。从项目代码中抽象出的理解是:VO对应于页面上须要显示的数据,DO对应于数据库中存储的数据,DTO对应于除两者以外须要进行传递的数据。 ## PO(persistant object) 持久对象 ## 在 o/r 映射的时候出现的概念,若是没有 o/r 映射,没有这个概念存在了。一般对应数据模型 ( 数据库 ), 自己还有部分业务逻辑的处理。能够当作是与数据库中的表相映射的 java 对象。最简单的 PO 就是对应数据库中某个表中的一条记录,多个记录能够用 PO 的集合。 PO 中应该不包含任何对数据库的操做。 ## DO(Domain Object)领域对象 ## 就是从现实世界中抽象出来的有形或无形的业务实体。 ## TO(Transfer Object) ,数据传输对象 ## 在应用程序不一样 tie( 关系 ) 之间传输的对象 ## DTO(Data Transfer Object)数据传输对象 ## 这个概念来源于J2EE的设计模式,原来的目的是为了EJB的分布式应用提供粗粒度的数据实体,以减小分布式调用的次数,从而提升分布式调用的性能和下降网络负载,但在这里,我泛指用于展现层与服务层之间的数据传输对象。 ## VO(value object) 值对象 ## 一般用于业务层之间的数据传递,和 PO 同样也是仅仅包含数据而已。但应是抽象出的业务对象 , 能够和表对应 , 也能够不 , 这根据业务的须要 。用 new 关键字建立,由 GC 回收的。 ## BO(business object) 业务对象 ## 从业务模型的角度看 , 见 UML 元件领域模型中的领域对象。封装业务逻辑的 java 对象 , 经过调用 DAO 方法 , 结合 PO,VO 进行业务操做。 business object: 业务对象 主要做用是把业务逻辑封装为一个对象。这个对象能够包括一个或多个其它的对象。 好比一个简历,有教育经历、工做经历、社会关系等等。 咱们能够把教育经历对应一个 PO ,工做经历对应一个 PO ,社会关系对应一个 PO 。 创建一个对应简历的 BO 对象处理简历,每一个 BO 包含这些 PO 。 这样处理业务逻辑时,咱们就能够针对 BO 去处理。 ## POJO(plain ordinary java object) 简单无规则 java 对象 ## 纯的传统意义的 java 对象。就是说在一些 Object/Relation Mapping 工具中,可以作到维护数据库表记录的 persisent object 彻底是一个符合 [Java ][Java 1]Bean 规范的纯 Java 对象,没有增长别的属性和方法。个人理解就是最基本的 Java Bean ,只有属性字段及 setter 和 getter 方法!。 ## DAO(data access object) 数据访问对象 ## 是一个 sun 的一个标准 j2ee 设计模式, 这个模式中有个接口就是 DAO ,它负持久层的操做。为业务层提供接口。此对象用于访问数据库。一般和 PO 结合使用, DAO 中包含了各类数据库的操做方法。经过它的方法 , 结合 PO 对数据库进行相关的操做。夹在业务逻辑与数据库资源中间。配合 VO, 提供数据库的 CRUD 操做. [Link 1]: http://www.javashuo.com/link?url=http://lib.csdn.net/base/mysql [64bfb689d48271f370372116e606bbc5.png]: /images/20221020/e13263aedf1a433d96125cbdb94a5bdd.png [64bfb689d48271f370372116e606bbc5.png 1]: http://www.javashuo.com/link?url=http://photo.blog.sina.com.cn/showpic.html#blogid=7a4cdec80100wkyh&url=http://s8.sinaimg.cn/orignal/7a4cdec8gb4957a56a3b7 [56c666d762dac330319a45ad3cd3d54d.png]: /images/20221020/c05b088ea3ca4de1a41aadcb944ca12d.png [Link 2]: http://www.javashuo.com/link?url=http://lib.csdn.net/base/datastructure [Link 3]: http://www.javashuo.com/link?url=http://lib.csdn.net/base/architecture [Java]: http://www.javashuo.com/link?url=http://lib.csdn.net/base/javase [Java 1]: http://www.javashuo.com/link?url=http://lib.csdn.net/base/java
还没有评论,来说两句吧...