实体类(VO,DO,DTO,PO)的划分

常常会接触到VO,DO,DTO的概念,本文从领域建模中的实体划分和项目中的实际应用状况两个角度,对这几个概念进行简析。html

得出的主要结论是:在项目应用中,VO对应于页面上须要显示的数据(表单),DO对应于数据库中存储的数据(数据表),DTO对应于除两者以外须要进行传递的数据。java

1、实体类mysql

百度百科中对于实体类的定义以下:算法

实体类的主要职责是存储和管理系统内部的信息,它也能够有行为,甚至很复杂的行为,但这些行为必须与它所表明的实体对象密切相关。sql

根据以上定义,咱们能够了解到,实体类有两方面内容,存储数据和执行数据自己相关的操做。这两方面内容对应到实现上,最简单的实体类是POJO类,含有属性及属性对应的set和get方法,实体类常见的方法还有用于输出自身数据的toString方法。数据库


 

 

2、领域模型中的实体类设计模式

领域模型中的实体类分为四种类型:VO、DTO、DO、PO,各类实体类用于不一样业务层次间的交互,并会在层次内实现实体类之间的转化。网络

业务分层为:视图层(VIEW+ACTION),服务层(SERVICE),持久层(DAO)数据结构

相应各层间实体的传递以下图:架构


 

项目中咱们并无严格遵循这种传递关系,但这种和业务层次的关联对咱们理解各实体类的做用是有帮助的。(咱们没有接触到PO的缘由,我理解为ORM对PO进行了封装)

如下是资料的原文,上图是基于此绘制的:

概念:

VO(View Object):视图对象,用于展现层,它的做用是把某个指定页面(或组件)的全部数据封装起来。

DTO(Data Transfer Object):数据传输对象,这个概念来源于J2EE的设计模式,原来的目的是为了EJB的分布式应用提供粗粒度的数据实体,以减小分布式调用的次数,从而提升分布式调用的性能和下降网络负载,但在这里,我泛指用于展现层与服务层之间的数据传输对象。

DO(Domain Object):领域对象,就是从现实世界中抽象出来的有形或无形的业务实体。

PO(Persistent Object):持久化对象,它跟持久层(一般是关系型数据库)的数据结构造成一一对应的映射关系,若是持久层是关系型数据库,那么,数据表中的每一个字段(或若干个)就对应PO的一个(或若干个)属性。

模型:

       下面以一个时序图创建简单模型来描述上述对象在三层架构应用中的位置

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 Bean 规范的纯 Java 对象,没有增长别的属性和方法。个人理解就是最基本的 Java Bean ,只有属性字段及 setter 和 getter 方法!。

DAO(data access object) 数据访问对象

是一个 sun 的一个标准 j2ee 设计模式, 这个模式中有个接口就是 DAO ,它负持久层的操做。为业务层提供接口。此对象用于访问数据库。一般和 PO 结合使用, DAO 中包含了各类数据库的操做方法。经过它的方法 , 结合 PO 对数据库进行相关的操做。夹在业务逻辑与数据库资源中间。配合 VO, 提供数据库的 CRUD 操做.

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值