vo、po、dto、bo、pojo、entity

2024-03-20 21:52
文章标签 po entity pojo vo bo dto

本文主要是介绍vo、po、dto、bo、pojo、entity,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

VO:Value Object,值对象。

  • 通常用于业务层之间的数据传递,由new创建,由GC回收;例如:将商品信息和用户信息重新用一个对象封装起来。
  • 和PO一样也是仅仅包含数据而已,但应是抽象出的业务对象,可以和表对应,也可以不是。
  • 另外一种说法:VO(View Object):VO是显示视图模型,视图对象,用于展示层,它的作用是把某个指定页面(或组件)的所有数据封装起来。举例:展示层将DTO传送过来男性显示成帅哥(客户端1),或者显示成靓仔(客户端2);将帅哥或者靓仔,转换成男性,以DTO形式请求服务端。

PO:Persistant Object,持久层对象。(可以认为就是Entity)

  • PO是 ORM 框架中Entity,PO属性和数据库中表的字段一一对应。
  • VO和PO,都是属性加上属性的get和set方法;表面看没什么不同,但代表的含义是完全不同的。基本上持久对象生命周期和数据库密切相关。

Entity:实体类对象。

  • 实体,和PO的功能类似,和数据表一一对应,一个实体一张表。
  • 注:关于区分POJO和entity,查了一些资料也没发现有特别大的差别,功能上来说差别不大,只能从含义上大致区分一下。不过现在大都是用entity来作为一个表映射的类。

DTO:Data Transfer Object,数据传输对象。

  • 在这里泛指用于展示层与服务层之间的数据传输对象。那么问题来了,为什么要用DTO呢? 为什么不能直接用实体模型呢?
  • 举个例子:
    • 比如我们一张表有100个字段,那么对应的PO就有100个属性。
    • 但是我们界面上只要显示10个字段。
    • 客户端用service来获取数据,没有必要把整个PO对象传递到客户端。
    • 这时我们就可以用只有这10个属性的DTO来传递结果到客户端,这样也不会暴露服务端表结构。
    • 简单来说:就是当数据库表中的字段太多了,只提取出数据表中的某些字段,将其封装为一个DTO对象传给客户端。
  • DTO由此产生,一是能提高数据传输的速度(减少了传输字段),二能隐藏后端表结构。

DO:Domain Object,领域对象,作用于业务层与dao层之间。

  • service使用接收到的DTO数据传输对象构造或者重构DO对象,传递到dao层。

BO:Business Object,业务对象。(不常用)

  • BO是封装业务逻辑的Java对象,通过调用DAO方法,结合PO,VO进行业务操作。
  • 举个例子:
    • 比如一个简历,有教育经历、工作经历、社会关系等。
    • 我们可以把教育经历对应一个PO,工作经历对应一个PO,社会关系对应一个PO。
    • 建立一个对应简历的BO对象处理简历,每个BO包含这些PO。
    • 这样处理业务逻辑时,我们就可以针对BO去处理。 

POJO:Plain Ordinary Java Object,简单无规则java对象。

  • 一般只有属性字段,无参构造以及get和set方法,也是指那些没有从任何类继承、也没有实现任何接口,更没有被其它框架侵入的Java对象。因此它特别灵活可扩展,可以实现让一个模型贯穿多个层,简单来说可以理解成不包含业务逻辑的单纯用来存储数据的Java类。
  • 可以转化为PO、DTO、VO。
    • 一个POJO持久化以后就是PO;
    • 直接用它传递、传递过程中就是DTO;
    • 直接用来对应表示层就是VO;

这篇关于vo、po、dto、bo、pojo、entity的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/830843

相关文章

Caused by: org.hibernate.MappingException: Could not determine type for: org.cgh.ssh.pojo.GoodsType,

MappingException:这个主要是类映射上的异常,Could not determine type for: org.cgh.ssh.pojo.GoodsType,这句话表示GoodsType这个类没有被映射到

DTO类实现Serializable接口的重要性

所谓序列化,简单一点理解,就是将对象转换成字节数组,反序列化是将字节数组恢复为对象。凡是要在网络上传输的对象、要写入文件的对象、要保存到数据库中的对象都要进行序列化。Java对象是无法直接保存到文件中,或是存入数据库中的。如果要保存到文件中,或是存入数据库中,就要将对象序列化,即转换为字节数组才能保存到文件中或是数据库中。文件或者数据库中的字节数组拿出来之后要转换为对象才能被我们识别,即反序列化。

回归预测 | Matlab基于贝叶斯算法优化XGBoost(BO-XGBoost/Bayes-XGBoost)的数据回归预测+交叉验证

回归预测 | Matlab基于贝叶斯算法优化XGBoost(BO-XGBoost/Bayes-XGBoost)的数据回归预测+交叉验证 目录 回归预测 | Matlab基于贝叶斯算法优化XGBoost(BO-XGBoost/Bayes-XGBoost)的数据回归预测+交叉验证效果一览基本介绍程序设计参考资料 效果一览 基本介绍 Matlab实现基于贝叶斯算法优化X

某PO手机市场竞争分析,巧用波特五力分析法找出核心竞争力!

某PO手机主要从事手机的生产与销售,最近推出了新款 Reno 系列 5G 手机。当前,苹果占据了高端市场,华为占据了中高端市场,而某 PO 手机则在剩余市场中与某 VO 和某米竞争。近年来,某 PO手机凭借中端 R 系列逐步取得市场份额。在这样的背景下,我们运用波特五力模型来分析某 PO 手机的外部环境。 1、波特五力模型案例分析:某PO手机 1.1 新进入者的威胁 由于电子产品市场竞争激烈

selenium 自动化之七----自动化测试PO设计模式

PO(Page Object) 是selenium 自动化测试项目开发的设计模式之一,主要体现在页面交互的封装,使测试案例关注与业务而非页面谢姐,提高测试的可读性 PO 设计模式的有点 :减少代码重复,提高用例可读性,提供用例的维护性及UI频繁变化的项目 ,可以通过page对象封装一个HTML页面,可以通过提供的api来操作页面元素,不用满大街的四处找元素 PO的工作原理:就是一步一步封装分离

由“为什么VO不能继承PO?” 引出的为什么组合优于继承?

简述VO、DTO、PO的概念。 如下概念是我个人的理解: VO(View Object): 视图对象,用于展示,这很好理解,就是前端页面所需数据封装,一般所需要的属性比 PO 多并且。DTO(Data Transfer Object): 数据传输对象,这个概念来源于J2EE的设计模式,原来的目的是为了EJB的分布式应用提供粗粒度的数据实体,以减少分布式调用的次数,从而提高分布式调用的性能和降低

mybatis-generator生成相对应的po、dao以及mapper

1、下载mybatis-generator相应的jar包文件,可以进入http://search.maven.org/#search找到不同版本的jar包; 2、进入http://mybatis.github.io/generator/configreference/xmlconfig.html官方网站查看官方文档,选择你相应的方式来生成po、dao、mapper文件,本来选择的是配置文件+ja

PO、VO、DTO

不知道有没有和我一样的职场新人小白有这样的疑惑,为什么一个实体类要有po、vo、dto,分这么多层有必要吗?我之前做项目的时候也接触到了这些分层,今天想写一篇来谈谈我对其的理解。 一. POJO 首先先认识一下POJO,POJO是指普通的Java对象,是一个简单的Java类,通常没有实现特定的接口或继承特定的类。POJO的涉及原则是简单、普通、存粹的Java对象。 POJO对象通常用于封装数

mvc模式中关于DTO层的简单使用

1、概念: DTO:Data Transfer Object,数据传输对象,起到数据封装与隔离的作用 2、应用介绍: 在实际项目中,DTO的分在两层传输,一层是service层向controller层,这一层的DTO封装service执行结果,给controller,简化业务数据,只提取部分业务相关字段或补充处理相关字段,不同业务可能有不同的此类dto,具有业务相关性; 另外一层

MyEclipse生成 Hibernate带注解的po实体类

1.进入MyEclipse Hibernate 2.创建一个数据库链接 3.添加数据库链接信息,主要这里要引人图中的三个jar包,和ip和端口 4.选择刚刚创建的数据库链接的一个表,右键点击它,选择Hibernate Reverse Engineering 5.配置Po 6.选择主键生成方