Object的划分

PO ( Persistant Object ) 持久对象

定义

PO就是对应数据库中某个表中的一条记录,多个记录可以用 PO 的集合。 PO 中应该不包含任何对数据库的操作。

DO(Domain Object)领域对象

定义

就是从现实世界中抽象出来的有形或无形的业务实体。

TO ( Transfer Object) 数据传输对象

定义

不同的应用程序之间传输的对象

DTO(Data Transfer Object)数据传输对象

定义

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

VO

第一种定义:( Value Object ) 值对象

通常用于业务层之间的数据传递,和 PO 一样也是仅仅包含数据而已。但应是抽象出的业务对象 , 可以和表对应 , 也可以不 , 这根据业务的需要 。用 new 关键字创建,由 GC 回收的。

第二种定义:( View Object ) 视图对象

接受页面传递来的数据,封装对象将业务处理完成的对象,封装成页面要用的数据

示例

前面我们遇到需要加到实体的属性,但是这个属性又不是数据库字段的,比如CategoryEntity的属性children,我们会用到这个注解:

@TableField(exist=false)

其实这样的注解加载数据库字段映射的实体上做是不规范的,以及一些校验注解等等其实我们都不应该加载数据库字段映射的实体上,我们应该定义VO来用于响应数据给页面和接收页面的请求参数。

以AttrVo为例:

 有个问题就是VO接收页面传入的参数,我们还需要转换到PO再存入数据库,从VO到PO一个一个字段的赋值岂不是很麻烦?

Spring提供了方法如下:

  BeanUtils.copyProperties(attrVo, attrEntity);

只要attrVo和attrEntity中同名同类型的字段,就会给attrVo的属性值赋值到attrEntity中。

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方法!

​ POJO 是 DO/DTO/BO/VO 的统称。

DAO ( Data Access Object ) 数据访问对象

定义

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

posted @ 2023-03-15 21:24  lucsa  阅读(18)  评论(0编辑  收藏  举报