关于model层建VO和PO,实体类(VO,DO,DTO)的划分

转自  https://blog.csdn.net/jeikerxiao/article/details/53301941

https://blog.csdn.net/wangxin1982314/article/details/51954264

 

一、PO
persistant object 持久对象,可以看成是与数据库中的表相映射的java对象。

二、VO
value object值对象。通常用于业务层之间的数据传递,和PO一样也是仅仅包含数据而已。但应是抽象出的业务对象,可以和表对应,也可以不,这根据业务的需要.

有一种观点就是:PO只能用在数据层,VO用在商业逻辑层和表示层。 
各层操作属于该层自己的数据对象,这样就可以降低各层之间的耦合,便于以后系统的维护和扩展。

1.三个概念
View Object(VO)
Business Object(BO)
Persistence Object(PO)
他们分别是三层结构的显示层、业务逻辑层和存储层内部使用的数据结构,它们还有一个统称,叫做数据对象Data Object(DO)。

我们也可以把VO,BO和PO看成是DO在不同阶段的不同表示形态。当一个DO从显示层开始穿越整个系统的时候,它的形态和结构就开始变化,从VO转变到BO,最终到PO,但是这个过程不一定是可逆的,这个过程如果反向,从PO->BO->VO,很可能就对应不同的对象了。比如当输入错误的时候,回馈页面可能就需要增加一个错误信息提示。虽然实际使用的时候,我们经常会忽略这种细微的差异性,实际上这个错误信息,只对显示层有意义。

2.DO的转换规律
DO的转换规律一般可以总结为如下的几个类型,实际变化则可以是各种类型的组合:

2.1属性内容的减少
属性内容的增减在DO不同形态之间的转变时候经常会发生。比如上例中添加用户LoginInfo对象的VO转换到BO的时候,就需要丢弃“重复输入密码”的属性。有些VO对象甚至根本不需要转换成BO。在BO转换成PO的时候同样也会有属性内容减少的情况出现,比如“部门”这类树状层次结构对象,因为运行效率的因素,也许会需要BO中有“下级部门列表”,实际存储到数据库的时候,PO只需要一个“上级部门ID”就可以了。

2.2对象内容的填充或者增加
属性内容同样会有可能增加,但是在系统处理DO转换的时候,属性增加可能就意味着需要进行额外的查询和填充,比如我们使用“用户名”和“密码”进行登录的时候,最终系统需要通过数据库查询得到并且存储“用户ID”,以此来保证用户的唯一性。又比如提交的数据存在校验错误,我们可能需要重新刷新该页面,并且增加新属性“ErrorMessage”,以便把它显示在界面上,提醒用户注意。

2.3对象的拆分和组合
我们可以看上面最后一个“添加用户”的例子,一个LoginInfo的BO转化为PO的时候被拆分成了2个对象,一个存放基本的用户信息,一个存放对应的Role信息。通常对象拆分的时候,常常需要填充或者补足新对象的内容;而对象合并的时候,常常出现内容减少的情况。

2.4对象或者属性类型的变化
出现对象属性类型的变化在VO到BO的转换中比较常见,比如把用户输入的生日转化为一个真正的DateTime类型。

2.5属性名称的变化
属性名称在转换过程中会有变化,一般这种情况应该尽可能不要出现,但是在项目重构的时候出现的概率较大。

除了DO不同形态之间的转换规律之外,不同形态内部还有不同的工作要做:

2.6校验
“不要相信任何用户的输入”,这是设计程序跟用户进行交互操作时候永远需要遵守的一个原则。也就是所有的外部输入都需要进行正确性的校验。校验器是分为两个层次,一个是属性层次的校验,比如“年龄”只能0到150之间有效。另外一个是对象层次的校验,或者说跨属性层次的校验,比如“年份输入闰年的时候,2月可以有29日”等。

校验并不是一个单纯的问题,几乎所有的业务逻辑校验基本都需要一次完整的贯穿所有层次的调用。代价颇大。这个也是为什么我们在显示层做很多事先校验,而一旦进入业务逻辑层的时候,校验就经常会被“事后校验”代替了,人们会使用抛出异常的方法来代替“事前检查”。

回头看SOA发现它并不属于表现层,而是属于业务逻辑层,换句话说它使用的DO必须是BO而不是VO。而所谓的SOA也不过就是分布的业务逻辑层而已。
--------------------- 
作者:jeikerxiao 
来源:CSDN 
原文:https://blog.csdn.net/jeikerxiao/article/details/53301941 
版权声明:本文为博主原创文章,转载请附上博文链接!

 

 

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

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

一、实体类

百度百科中对于实体类的定义如下:

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

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

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

 

二、领域模型中的实体类

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

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

相应各层间实体的传递如下图:

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

 

项目中我们并没有严格遵循这种传递关系,但这种和业务层次的关联对我们理解各实体类的作用是有帮助的。(我们没有接触到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        对于一个逆向操作,如读取数据,也是用类似的方式转换和传递,略。

三、项目中的实体类

项目中常见的实体类有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 操作.

### 回答1: 实体类是指在面向对象编程中,用于表示某个具体实体的类,通常包含属性和方法。 VO(Value Object)是值对象,用于封装一些简单的数据,通常不包含业务逻辑。 DO(Data Object)是数据对象,用于封装数据库中的数据,通常与数据库表一一对应。 DTO(Data Transfer Object)是数据传输对象,用于在不同层之间传输数据,通常包含多个实体类的属性。 POJO(Plain Old Java Object)是一个简单的Java对象,通常不包含业务逻辑和特殊的API,用于表示某个具体实体。 ### 回答2: 实体类VO、DO、DTOPOJO都是面向对象编程中用来表示某个概念的对象。 实体类是一个具体的物体或概念的抽象表示,通常对应着数据库中的某个表。实体类的属性直接映射到数据库表的列,同时实体类中的方法用于实现该物体或概念的相关行为。 VO(Value Object),又称值对象,通常用于在不同层之间的数据传输,该对象通常只包含数据但不涉及任何业务逻辑。VO对象通常由业务层封装,一般不直接与数据库打交道。 与VO相对,在操作数据库时通常需要使用DO(Data Object),该类是与数据库表往来的载体。DO通常没有业务逻辑,只是一个映射关系的载体。 DTO(Data Transfer Object),表示数据传输对象,通常用于不同进程或不同系统之间的数据传输,其数据与VO类似,也是只包含数据且无业务逻辑。DTO对象可能需要转化为VO对象或DO对象,它可以转化为任何需要的目标类型。 POJO(Plain Old Java Object),指普通的Java对象,不是EJB(Enterprise JavaBean)或其它任何特殊规范的对象。POJO可以独立于特定框架,它没有限定,没有约束,也没有封装。 这四个对象概念都是为了更好地实现面向对象编程的思想,便于设计和实现高效可靠的程序。不同的对象概念针对不同的应用场景,需要我们在具体情况中选择合适的对象概念。 ### 回答3: 实体类是指用于表示系统中各种实际对象的类,包含对象所具有的属性和方法。这些实体类通常会包含系统中所必需的业务逻辑,它们是设计良好的对象模型的重要组成部分。 VO(Value Object)是一种轻量级的Java对象,通常用于封装系统中的数据。VO通常包含系统所需的最基本的数据,没有业务逻辑。它通常用于在不同层之间进行传递,例如在业务层和展示层之间传递数据。 DO(Data Object)是指数据对象,通常是对数据库中的一条记录进行封装,用于在 DAO 层和 Service 层之间传递数据。与VO不同的是,DO通常包含一些业务逻辑。 DTO(Data Transfer Object)是数据传输对象,通常是表示系统中某个具体领域的完整模型。DTO包含了与该领域相关的所有数据,用于在应用程序的不同层之间传递数据。通常,DTO包括了多个DO和VOPOJO(Plain Old Java Object)是一种普通的Java对象,不依赖于框架,没有实现任何接口或集成任何类库,仅包含了与业务相关的属性和方法。POJO是一种非常纯粹和简单的对象模型,它通常用于表示应用程序的领域模型。 总之,实体类VO、DO、DTOPOJO 在不同的应用场景中都有自己的作用。在设计和开发时应当根据实际情况选择合适的类别进行开发和应用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值