前言
在日常开发中,VO,BO,PO,DO,DTO都是常见的术语,用于区分和标识代码的,可能每家公司对这些常见的术语描述不一样。
DTO
DTO(Data Transfer Object)用于在不同层之间的传输数据的对象,解决不同层之间数据传输的问题,通过封装数据并提供对数据的访问方法,实现数据在不同层之间的传递。DTO的优点是可以抽象和封装传输的数据,让数据简单明了和可以控制,避免直接传递领域对象的实体,减少耦合性。能够根据业务灵活定义对应的DTO,还可以进行数据验证和转换,保证了数据的格式。
举个例子,现在开发一个图书管理后台,有如下几个层:
- 数据库层:与数据库交互
- 业务层:处理业务逻辑,比如:借书,还书的操作
- 控制层:对外提供API,处理用户请求并调用业务层
- 表现层(展示层):展示数据给用户,并接收用户的输入。
这个例子中,DTO用于控制层和表现层之间的数据传输,用户在图书管理后台进行登录的时候,输入账号密码,表现层将用户输入的数据封装到控制层的DTO对象中,控制层接收到DTO对象后,解析参数,调用业务层。
public class UserDTO {
private String username;
private String password;
// 省略构造方法和getter/setter
@Override
public String toString() {
return "UserDTO{" +
"username='" + username + '\'' +
", password='" + password + '\'' +
'}';
}
}
@RestController
public class UserController {
@PostMapping("/register")
public void registerUser(@RequestBody UserDTO userDTO) {
// 接收客户端传递的UserDTO对象,并进行业务处理
System.out.println("注册用户:" + userDTO);
// 调用业务层的方法进行用户注册逻辑
// ...
}
}
VO
VO,全称是View Object,也有说是Value Object的。一般是DTO转换为VO,返回给前端。简单说就是展示需要用到的数据字段,比如页面需要展示用户的姓名,年龄和性别,VO就是下面这样的
{
"name":"赵东洋",
"age":23,
"gender":"男"
}
如果说是个电商项目,在用户填写收货人性别的时候,性别男需要替换为先生,VO可以是下面这样的。
{
"name":"赵东洋",
"age":23,
"gender":"先生"
}
PO
PO是和数据库字段一一对应的,用于和数据库进行交互,映射数据库表的对象。它包含了表的属性d的Getter和Setter方法,例如:
这是PO属性:
public class User {
/**
* 用户id
*/
private Integer uid;
/**
* 用户名字
*/
private String uname;
/**
* 用户性别
*/
private String usex;
}
数据库字段就是下面这样的
BO
BO(bussines object)业务对象:主要在服务内部使用的。BO对象可以是一个对象,也可以包含多个对象,例如:现在有个一个家庭对象BO,这个家庭是由爸爸对象,妈妈对象,我对象组成。爸爸对象,妈妈对象,我对象是PO。
DO
DO有两个版本的解释:
- 在阿里巴巴开发手册中,DO对象是与数据库表结构对应的。
- 在DDD领域驱动中,DO等同于BO。