PO(Persistant Object)持久对象
通常对应数据模型(数据库),本身还有部分业务逻辑的处理。可以看成是与数据库中的表相映射的 Java 对象。最简单的 PO 就是对应数据库中某个表中的一条记录,多个记录可以用 PO 的集合,只能存活在一个数据库连接中,断开连接即被销毁
DO(Domain Object)领域对象
就是从现实世界中抽象出来的有形或无形的业务实体。一般和数据中的表结构对应,通过 DAO 层向上传输数据源对象
VO(Value Object)值对象
显示层对象,通常是 Web 向模板渲染引擎层传输的对象
用于表示一个与前端进行交互的 Java 对象。VO 只包含前端需要展示的数据即可,对于前端不需要的数据,比如数据创建和修改的时间等字段,出于减少传输数据量大小和保护数据库结构不外泄的目的,不应该在 VO 中体现出来。通常遵守 Java Bean 的规范,拥有 getter/setter 方法
DTO(Data Transfer Object)数据传输对象
DTO 通常用于不同服务或服务不同分层之间的数据传输,通常遵守 Java Bean 的规范,拥有 getter/setter 方法。比如我们一张表有 100 个字段,那么对应的 PO 就有 100 个属性。 但是我们界面上只要显示 10 个字段,没有必要把整个 PO 对象传递到客户端,这时我们就可以用只有这 10 个属性的 DTO 来传递结果到客户端,这样也不会暴露服务端表结构。到达客户端以后,如果用这个对象来对应界面显示,那此时它的身份就转为 VO。DTO 与 VO 概念相似,并且通常情况下字段也基本一致。但 DTO 与 VO 又有一些不同,这个不同主要是设计理念上的,比如 API 服务需要使用的 DTO 就可能与 VO 存在差异
BO(Business Object)业务对象
封装业务逻辑的 Java 对象,通过调用 DAO 方法,结合 PO,VO 进行业务操作。 主要作用是把业务逻辑封装为一个对象。这个对象可以包括一个或多个其它的对象。比如一个简历,有教育经历、工作经历、社会关系等等。 我们可以把教育经历对应一个 PO,工作经历对应一个 PO,社会关系对应一个 PO。 建立一个对应简历的 BO 对象处理简历,每个 BO 包含这些 PO。这样处理业务逻辑时,我们就可以针对 BO 去处理
DAO(Data Access Object)数据访问对象
是 sun 的一个标准 j2ee 设计模式,这个模式中有个接口就是 DAO,它负责持久层的操作,为业务层提供接口。此对象用于访问数据库,通常和 PO 结合使用,DAO 中包含了各种数据库的操作方法。通过它的方法,结合 PO 对数据库进行相关的操作
DTO(Data Transfer Object)数据传输对象
主要用于远程调用等需要大量传输对象的地方。 比如我们一张表有 100 个字段,那么对应的 PO 就有 100 个属性。 但是我们界面上只要显示 10 个字段, 没有必要把整个 PO 对象传递到客户端, 这时我们就可以用只有这 10 个属性的 DTO 来传递结果到客户端,这样也不会暴露服务端表结构。到达客户端以后,如果用这个对象来对应界面显示,那此时它的身份就转为 VO
TO(Transfer Object)数据传输对象
在应用程序不同 tie(关系)之间传输的对象
POJO( Plain Ordinary Java Object)简单无规则 Java 对象
专指只有 setter/getter/toString的简单类,包括 DO/DTO/BO/VO 等
网友评论