VO、DTO、BO、PO、DO、POJO 数据模型的理解和实际使用

一、概念讲解

  • VO(View/Value Object)—— 视图对象
    用于展示层,它的作用是把某个指定页面(或组件)的所有数据封装起来。
  • DTO(Data Transfer Object)—— 数据传输对象
    这个概念来源于J2EE的设计模式,原来的目的是为了EJB的分布式应用提供粗粒度的数据实体,以减少分布式调用的次数,从而提高分布式调用的性能和降低网络负载,但在这里,我泛指用于展示层与服务层之间的数据传输对象。
  • BO(Business Object)—— 业务对象
  • PO(Persistent Object)—— 持久对象
    持久化对象(例如:entity、bean),他跟持久层(通常是关系型数据库)的数据结构形成一一对应的映射关系,如果持久层是关系型数据库,那么,数据表中的每个字段(或若干个)就对应PO的一个(或若干个)属性。
  • DO(Data/Domain Object)—— 数据/领域对象
    就是从现实世界中抽象出来的有形或无形的业务实体。
  • POJO(Plain Old/OrdinaryJava Object)—— 以上模型的统称
    POJO 是简单的 Java 对象,不包含业务逻辑、能够控制自己内部所有属性访问的 Java 对象。

二、概念澄清

JavaBean vs POJO

  • JavaBean 其实是 POJO 的一种形式(JavaBean < POJO
JavaBeanPOJO
没有业务逻辑没有业务逻辑
必须构造函数无需构造函数
private 修饰成员变量成员变量的修饰符无限制

三、使用场景

关系图说明:
在这里插入图片描述

从上到下依次说明:

  • VO(View/Value Object)—— 视图对象
    VO 就是展示用的数据,不管展示方式是网页、客户端、APP,只要是这些数据用于展示给人看的就是 VO

  • DTO(Data Transfer Object)—— 数据传输对象
    数据传输对象比较特殊,之所以将DTO绘制在【展示层】和【业务逻辑层】之间,是因为它有两种存在形式:

    • 前端:它是以Json字串的形式存在
    • 后端:它是以Java对象的形式存在

    微服务之间DTO对象的模型鉴定形式:

    • 服务(模块)与服务(模块)之间相对独立,我们可以将数据传输对象命名为 DTO
    • 服务(模块)与服务(模块)之间不是独立,每一个都不是一个完整的业务模块,拆分可能仅仅是因为计算复杂度或者性能问题考虑拆分的问题,那么就不能将对象命名为 DTO只能BO
VO vs DTO
区别一:
字段可能不一样,VO 会根据实际情况,对字段有所删减
区别二:
属性值可能不一样,VO 会根据 DTO 中对值进行展示业务对解释(比如:为不暴露数据库字段,修改属性名称、敏感字段不展示等等)
  • BO(Business Object)—— 业务对象
    BO 就是 PO 的组合

    • 简单解释:
      比如:PO 是一个交易记录,BO 就是一个人全部的交易记录集合对象
    • 复杂解释:
      比如:PO1 是交易记录,PO2 是登录记录、PO3 是商品浏览记录、PO4 是添加购物记录,BO 就是个人网站行为对象
  • PO(Persistent Object)—— 持久对象
    简单的说 PO就是数据库中的记录,一个 PO 的数据结构对应着库中的表结构,表中的一条记录就是一个 PO 对象。对于 PO 来说,数量是相对固定的,不会超过数据库中表的数量。等同于 Entity,它两概念是一致的。

  • DO(Data/Domain Object)—— 数据/领域对象

    • 阿里开发手册
      DO 等同于 PO
    • DDD 领域驱动设计
      DO 等同于 BO
DO vs DTO
这两个的区别主要也是字段的删减。
BO 对内,为了进行业务计算需要辅助数据或者一个业务有多个对外接口,BO 可能会含有很多接口对外所不需要的数据,因此 DTO 需要在 BO 的基础上选取自己所需的数据赋值。

四、经验总结

  1. PO(Entity) 这个是没有办法省略的,所有涉及数据库操作的都需要有持久化对象
  2. 不是非常大型的简单系统,DTOBO 可以合并为一个,当业务扩展的时候注意拆分即可
  3. 概念是给人用的,多人协作的时候一定要保证大家的概念一致。请勿形而上学、过度设计、一切设计都基于现有的业务规则和系统大小

五、拓展阅读

### 回答1: povobodto、daopojo都是Java编程中常用的缩写词。 - po:通常指持久化对象(Persistent Object),即数据库中的实体类,与数据库中的一一对应。 - vo:通常指值对象(Value Object),用于封装业务逻辑中的数据,与前端展示相关。 - bo:通常指业务对象(Business Object),用于封装业务逻辑中的数据,与业务逻辑相关。 - dto:通常指数据传输对象(Data Transfer Object),用于在不同层之间传输数据,通常与前端展示无关。 - dao:通常指数据访问对象(Data Access Object),用于封装对数据库的访问,提供对数据库的增删改查操作。 - pojo:通常指普通Java对象(Plain Old Java Object),即普通的Java类,没有继承特定的接口或类,也没有实现特定的方法。 ### 回答2: po vo bo dto dao pojo 是软件开发中经常使用的一些概念,用于设计实现对象模型。下面将分别解释这些概念的含义及其在开发中的应用。 Po是指Persistant object(持久化对象),是映射到数据中的Java对象。Po主要用于数据交互,与数据结构一一对应,包含了与实体对象映射一一对应的Po实体。在开发中,如果需要进行数据库操作,则需要通过Po实体与数据库进行交互,从而实现对数据的增、删、改、查等操作。 Vo是指Value object(值对象),用于封装特定业务数据VoPo不同的是,Vo不仅包含了与数据库映射的数据,还包含了其他一些数据字段,例如计算、统计字段等。Vo主要用于业务层的数据处理交互,封装业务逻辑用于VO来完成,并作为业务组件的数据传递对象。 Bo是指Business object(业务对象),用于封装业务逻辑。Bo封装了特定的业务方法,实现相应的业务功能。Bo通过调用Dao进行持久化操作,或管理多个Bo进行协作完成更复杂的业务逻辑。 Dto是指Data transfer object(数据传输对象),主要用于接口层远程调用时数据传输的封装。Dto通常包含一些传输时需要的字段,例如查询条件、分页信息等。Dto主要用于数据的传输,不包含业务逻辑。 Dao是指Data access object(数据访问对象),用于将数据访问与业务逻辑分离,Dao通过对Po对象进行CRUD操作,实现与数据库的交互。Dao在进行数据库操作时往往需要配合使用数据访问框架,例如Mybatis、Hibernate等。 Pojo是指Plain Ordinary Java object(简单Java对象),是一种纯粹的Java对象,不依赖于其他任何框架。Pojo一般用于传输数据、封装业务实体等。PojoVo比较相似,但Vo作为业务层的数据传输对象,常常包含业务逻辑,而Pojo则不会。 总之,这些概念在软件开发中的使用是相当普遍的,通过合理地使用这些概念,可以使开发者更加清晰地理解业务的实现方式,增加代码的可读性可维护性。选择何种概念,最终需要根据具体的业务场景及功能需求决定。 ### 回答3: POVOBODTO、DAOPOJO都是Java中的术语。 PO指的是“持久化对象”,是用于描述持久化存储模型的Java对象,通常数据库中的一一对应。 在ORM(对象关系映射)框架中,PO可以将Java对象映射到数据库中的,简化了数据的存储持久化过程。 VO指的是“值对象”,是用于描述值的Java对象,通常是由一个或多个PO组成的。VO通常是用于在不同层之间传递数据的,例如将从数据库中查询出来的PO转化成前台可以直接使用VO,或者将前台传入的VO转化成后台PO以进行数据的持久化存储。 BO指的是“业务对象”,是用于描述业务逻辑的Java对象,通常是由对应的多个POBODTO组成的。BO主要负责处理业务逻辑,可以看成是对PO进行多层封装后产生的对象,也可以是多个PO的组合。 DTO指的是“数据传输对象”,是用于数据传输的Java对象,通常是由一个或多个POBODTO组成的。DTO主要用于在不同模块之间传输数据,可以对数据进行封装裁剪。 DAO指的是“数据访问对象”,是用于数据访问的Java对象,通常是负责封装数据访问层的操作,例如对数据库的增删改查等操作。DAO通过提供独立的接口,将访问数据的过程与业务分离,增强了代码的可重用性可维护性。 POJO指的是“简单Java对象”,是一种不包含业务方法的Java对象,通常是用于封装数据Java Bean。POJOJava EE相关性较小,可以将其看成是一种简化的Java类实现方式,适用于需要快速实现业务逻辑的场景。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值