DO、PO、BO、DTO、VO等概念

PO前端

全称为:Persistant Object,持久化对象,与数据库结构映射的实体,数据库中的一条数据即为一个 PO 对象。数据库

 

BO数据结构

全称为:Business Object,业务对象,主要做用是把业务逻辑封装成一个对象,这个对象能够包括一个或多个其它对象。
好比一个简历 BO 中有教育经历,工做经历,社会关系等多个 PO 对象。spa

 

DTOserver

全称为:Data Transfer Object,数据传输对象,好比一张表有 100 个字段,那么对应的 PO 就有100 个属性(大多数状况下,DTO内部的数据结构来自多个表)但 view 层只须要显示 10 个字段,没有必要把整个 PO 对象传递到 client,这时咱们就能够用只有这 10 个属性的 DTO 来传输给 client,这样也不会暴露 server 端表结构,到达客户端后,若是这个对象来对应页面显示,它的身份就转为 VO。对象

 

使用场景:继承

  • UserDTO 不该该返回用户密码。
  • UserDTO 包含归属部门名称,而 UserPO 只有 deptId,没有部门名称。
  • 后台表有 100 个字段,但前端展现只须要 10 个字段,减小数据传输。
  • 简历 ResumeDTO 包含教育经历、工做经历、社会关系等多个表的数据。

 

VO后台

全称为:View Object,主要对应页面展现的数据对象,通常继承自 PO,能够添加 PO 中没有的字段,用来逻辑处理以及其它消息存储。cli

 

DO表单

全称为:Domain Object,领域对象,从现实世界中抽象出的业务实体,它不是简单的 POJO,它具备业务领域逻辑。

 

DAO

全称为:Data Access Object,数据访问对象,通常所说的 DAO 层,用于链接数据库与外层之间的桥梁,并持久化数据层对象。

 

模型

  • 用户发出请求,表单的数据层被匹配为 VO。
  • 展现层把 VO 转换为服务层对应方法锁要求的 DTO,传输给服务层。
  • 服务层首先根据 DTO 的数据构造一个 DO,调用 DO 的业务方法完成具体业务。
  • 服务层把 DO 转换为持久层对应的 PO,调用持久层持久化方法,把 PO 传递给它完成持久化操做。
相关文章
相关标签/搜索