分层对象模型:PO、DTO、VO、BO定义区别与使用场景

news2025/4/16 23:11:40

目录

前言

PO(持久化对象)

DTO(数据传输对象)

VO(视图对象)

BO(业务对象)

关键区别总结

典型应用场景 

为什么要分层设计

工具支持


前言

在开发中,我们经常遇到一些对象,如VO、DTO、PO、BO这些,搞不懂为什么要分这么多对

象,直接查询出对象实体类返回不就可以了吗?其实每个对象模型都有不同含义和作用,我们主要

说一下这几个对象模型在开发中的用途和区别。

PO(持久化对象)

作用:直接映射数据库表结构,与数据库交互的实体,数据库结构是怎么样的,PO就是对应数据

库库表结构。

特点

  • 通常与ORM框架(如Hibernate、MyBatis)配合使用。
  • 字段与数据库一一对应,可能包含数据库特有的注解(如@Table、@Column)

示例

@Entity
@Table(name = "user")
public class UserPO {
    @Id
    private Long id;
    private String name;
    private String email;
    // Getters & Setters
}

DTO(数据传输对象)

作用:用于不同层(Controller层与Service层)之间数据传输,避免暴露敏感数据或冗余字段,一

般用于Controller层接收传递给Service进行业务处理,或者一般远程调用(如RPC接口)或微服务

之间通信。

特点

  • 按需组合数据,可能包含多个PO的字段。

示例:

public class UserDTO {
    private Long id;
    private String name;
    // 不返回email,避免隐私泄露
    // Getters & Setters
}

VO(视图对象)

作用:面向前端展示,封装页面需要的数据,可能包含格式化后的数据。

特点:

  • 结构与前端UI强相关,可能组合多个业务数据。

  • 例如:日期格式化为字符串、状态码转文字描述。

示例

public class UserVO {
    private String userName;
    private String registerDate; // 格式化为"yyyy-MM-dd"
    // Getters & Setters
}

BO(业务对象)

作用:封装复杂的业务逻辑,代表业务处理最小单元。

特点

  • 可能聚合多个PO的数据,并包含业务方法。
  • 例如:订单BO包含订单信息、用户信息、商品列表及计算总价的方法。

示例

public class OrderBO {
    private OrderPO orderPO;
    private UserPO userPO;
    private List<ProductPO> products;
    
    public BigDecimal calculateTotalPrice() {
        // 业务逻辑:计算订单总价
    }
}

关键区别总结

对象层级核心用途数据特点
PO数据访问层(DAO)直接对应数据库表结构与数据库字段严格一致
DTO服务层/控制层之间跨层传输数据,屏蔽敏感字段按需组合,无业务逻辑
VO控制层/前端适配前端展示需求格式化数据,结构灵活
BO业务逻辑层(Service)封装复杂业务逻辑聚合多个PO,包含业务方法

典型应用场景 

  • 用户注册流程
  1. 前端提交表单——>DTO接收(如UserCreateDTO)。
  2. Service层将DTO转化为PO存入数据库。
  3. Service层可能通过BO组合用户、权限数据。
  4. 返回给前端时,PO转为VO(如隐藏密码,格式化日期)
  • 微服务PRC调用
  1. 服务A通过DTO向服务B请求数据。
  2. 服务B从数据库获取PO,转换DTO返回。

为什么要分层设计

  • 解耦:各层职责单一,修改数据库字段不影响前端展示。
  • 安全:DTO和VO可过滤敏感字段(如密码、手机号)。
  • 复用性:BO封装通用业务逻辑,避免代码重复。
  • 灵活性:VO可自由适配不同前端请求(Web、App、小程序)。

工具支持

对象转换工具:

  • MapStructPlus:通过注解自动生成转换代码。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2335394.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

设计模式 --- 状态模式

状态模式​​是一种​​行为型设计模式​​&#xff0c;允许对象在内部状态改变时动态改变其行为​​&#xff0c;使对象的行为看起来像是改变了。该模式通过将状态逻辑拆分为独立类​​&#xff0c;消除复杂的条件分支语句&#xff0c;提升代码的可维护性和扩展性。 状态模式的…

深入剖析Go Channel:从底层原理到高阶避坑指南|Go语言进阶(5)

文章目录 引言channel的底层数据结构channel操作原理发送操作(ch <- data)接收操作(<-ch) 常见陷阱及避坑指南1. 死锁问题2. 关闭channel的错误方式3. 内存泄漏4. nil channel特性5. 性能考量 最佳实践总结 引言 Channel是Go语言实现CSP并发模型的核心机制&#xff0c;提…

OpenCV 图形API(31)图像滤波-----3x3 腐蚀操作函数erode3x3()

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 使用3x3矩形结构元素腐蚀图像。 该函数通过使用中心作为锚点的3x3矩形结构元素来腐蚀源图像。腐蚀操作可以应用多次&#xff08;迭代&#xff0…

AI Agent开发大全第二十八课-MCP实现本地命令调用怎么做的?

开篇 MCP很强大,Client端一旦实现了稳定的连接和执行流程后任Server端随意改动都可兼容,这就是热插拨功能。 如果我们仅仅满足于MCP查点网上资料、读点图片即文字型的功能肯定是不能充分发挥MCP的强大之处的,正应了Google以及Anthropic最近的研究报告上说的:不要再在chat…

A2A协议实现详解及示例

A2A协议概述 A2A (Agent2Agent) 是Google推出的一个开放协议&#xff0c;旨在使AI智能体能够安全地相互通信和协作。该协议打破了孤立智能体系统之间的壁垒&#xff0c;实现了复杂的跨应用自动化。[1] A2A协议的核心目标是让不同的AI代理能够相互通信、安全地交换信息以及在各…

活动图与流程图的区别与联系:深入理解两种建模工具

目录 前言1. 活动图概述1.1 活动图的定义1.2 活动图的基本构成要素1.3 活动图的应用场景 2. 流程图概述2.1 流程图的定义2.2 流程图的基本构成要素2.3 流程图的应用场景 3. 活动图与流程图的联系4. 活动图与流程图的区别4.1 所属体系不同4.2 表达能力差异4.3 使用目的与语境4.4…

图片文本识别OCR+DeepSeekapi实现提取图片关键信息

用到的技术&#xff1a; 通过腾讯OCR文字识别&#xff0c;deepseek的api实现 目录 需求分析&#xff1a; 文字识别&#xff08;OCR&#xff09;具体实现步骤 起步工作 代码编写 deepseek整合消息&#xff0c;返回文本关键信息 起步工作 编写工具类 具体调用实现 具体…

go 通过汇编分析函数传参与返回值机制

文章目录 概要一、前置知识二、汇编分析2.1、示例2.2、汇编2.2.1、 寄存器传值的汇编2.2.2、 栈内存传值的汇编 三、拓展3.1 了解go中的Duff’s Device3.2 go tool compile3.2 call 0x46dc70 & call 0x46dfda 概要 在上一篇文章中&#xff0c;我们研究了go函数调用时的栈布…

解决Ubuntu Desktop 24.04 VMware中安装后不能全屏显示,只能居中的问题

Ubuntu Desktop 24.04 VMware中安装后不能全屏显示&#xff0c;只能居中。 sudo apt-get install open-vm-tools sudo apt-get install open-vm*

【笔记ing】AI大模型-04逻辑回归模型

一个神经网络结构&#xff0c;其中的一个神经网络层&#xff0c;本质就是一个逻辑回归模型 深度神经网络的本质就是多层逻辑回归模型互相连接或采用一定的特殊连接的方式连接在一起构成的。其中每一个层本质就是一个逻辑回归模型。 逻辑回归模型基本原理 逻辑回归&#xff0…

记录学习的第二十五天

今天终于又开始更新了。实在是星期六的蓝桥杯给了我一个大大的打击&#xff0c;今天终于好不容易缓过来了&#xff0c;可以好好学算法了。 还是老规划&#xff0c;力扣的每日一题。不过今天的每日一题我之前做过了&#xff0c;就又提交了一次来签到。 之后三道哈希表题目。 我一…

linux电源管理(二),内核的CPUFreq(DVFS)和ARM的SCPI

更多linux系统电源管理相关的内容请看&#xff1a;https://blog.csdn.net/u010936265/article/details/146436725?spm1011.2415.3001.5331 1 简介 CPUFreq子系统位于drivers/cpufreq目录下&#xff0c;负责进行运行过程中CPU频率和电压的动态调整&#xff0c;即DVFS (Dynami…

ES6学习04-数组扩展:扩展运算符、新增方法

一、扩展运算符 1. 2. eg: 3. 二、新增方法 1. arguments 元素组合 类似数组对象 2.

滚轮控制目标臂长度调整相机距离

通过鼠标滚轮来控制摄像机目标臂长度 , 调整相机距离 看图就行,不多说,照着连就完事了

​‌FireCrawl‌爬虫工具​, Craw4ai

‌FireCrawl‌是一款开源的AI爬虫工具&#xff0c;专门用于Web数据提取&#xff0c;并将其转换为Markdown格式或其他结构化数据。FireCrawl特别适合处理使用JavaScript动态生成的网站&#xff0c;能够自动抓取网站及其所有可访问的子页面内容&#xff0c;并将其转换为适合大语言…

pyenv库应用入门与Ubuntu端安装实践

pyenv库应用入门与Ubuntu端安装实践 pyenv概述virtualenv、pyvenv、pyenvvirtualenvpyvenvpyenv Ubuntu端安装pyenv实践安装依赖报错解决安装pyenv配置环境变量更换pyenv源地址 pyenv基本用法安装成功服务器部署scrapyd pyenv概述 pyenv 是一个用于管理多个 Python 版本的工具…

CS5346 - Annotation in Visualization (可视化中的注释)

文章目录 Annotation 的重要性Levels of Annotation &#xff08;注释的层级&#xff09;Headings and IntroductionHeadings&#xff08;标题&#xff09;陈述型&#xff08;Statement&#xff09;&#xff1a;突出结论或有趣发现疑问型&#xff08;Question&#xff09;&…

如何开发一套场外个股期权交易系统?个股期权交易软件包含:询价,报价,交易,持仓,行权,账户盈亏统计等

一、场外个股期权的定义与特点 场外个股期权&#xff08;Over-the-Counter Equity Option&#xff09;是一种由交易双方私下协商的非标准化金融衍生品合约&#xff0c;以特定个股为标的资产。与交易所上市的标准化期权不同&#xff0c;其合约条款&#xff08;如行权价、到期日…

高速电路中的电阻、电容的选型及应用

2.1 电阻的应用 2.1.1 与电阻相关的经典案例 如果说芯片是电路的骨架&#xff0c;那么电阻就是在芯片之间起连接作用的关节。电阻的阻值、布放位置等&#xff0c;对设计的成功起着至关重要的作用。 【案例2.1】串联电阻过大&#xff0c;导致板间告警失败 某产品由业务板和主…

六、adb通过Wifi连接

背景 收集是荣耀X40,数据线原装全新的&#xff0c;USB连上之后&#xff0c;老是断&#xff0c;电脑一直叮咚叮咚的响个不停&#xff0c;试试WIFI 连接是否稳定&#xff0c;需要手机和电脑用相同的WIFI. 连接 1.通过 USB 连接手机和电脑(打开USB调试等这些都略过) adb device…