展开

关键词

PO,BO,VO,DTO

VO是拿给前端展示给用户的实体 a) 有一些敏感的属性不能给前端展示,涉及安全问题 4、为什么要有DTO? 1、前端传给我们的参数我们自动封装成了VO 2、我们在Controller里把VO转成了BO,然后调用Service里的方法 3、Service层处理业务的时候发现要调用一个外部服务,那么就组装一个DTO 参数去调用外部RPC服务,最终得到的DTO的结果我们在转成我们自己的BO再参与到业务处理中 4、Service处理的结果要查询DB,那么从DAO层返回来的是一个PO,我们也是把PO先转成我们的BO在参与业务处理

10330

Java中常见的对象类型简述(DO、BO、DTO、VO、AO、PO)

DTO(Data Transfer Object):数据传输对象,这个概念来源于J2EE的设计模式,原来的目的是为了EJB的分布式应用提供粗粒度的数据实体,以减少分布式调用的次数,从而提高分布式调用的性能和降低网络负载

11410
  • 广告
    关闭

    腾讯云服务器买赠活动

    腾讯云服务器买赠活动,低至72元1年,买就送,最长续3个月,买2核送4核、买4核送8核

  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    简单Java 多表联查分页显示(初)

    Java 多表联查分页显示 操作步骤: 建立数据库 使用Servlet 创建Java项目 编写代码 ---- 1、数据库 选用 Oracle 代码附上: drop table Score; drop " import="java.util.*" pageEncoding="utf-8"%> <%@ taglib uri="http://<em>java</em>.sun.com/jsp/jstl/core" prefix 接口实现类 package dao.impl; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet ; import java.sql.SQLException; import java.util.ArrayList; import java.util.List; import dao.BaseDao package dao; import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet;

    16630

    不,这样的 DTO

    DTO! by Robert C. 其中一位程序员使用了 RowFixture(一种测试结果比较的工具,译注),这种工具需要使用 DTO(数据传输对象)并且要求其中的变量都为公有的。 这时候这位程序员提出了质疑:“DTO 应该使用私有的变量和一套相应的 getter、setter 方法!”,“为什么呢?” 我问。 到底是为什么?

    6410

    何时使用Entity或DTO

    点击左上角,关注:“乱敲代码” JPA和 Hibernate允许你在 JPQL和 Criteria查询中使用 DTO和 Entity作为映射。 1.DTO与Entity之间的主要区别 Entity和 DTO之间常被忽略的区别是—— Entity被持久上下文(persistence context)所管理。 = System.currentTimeMillis(); List<BookValue> books = em.createQuery("SELECT new org.thoughts.on.java.model.BookValue 使用 DTO投影的查询比选择实体的查询快约40%。因此,最好花费额外的精力为你的只读操作创建 DTO并将其用作投影。 此外,还应确保对所有关联使用 FetchType.LAZY。 原文链接:https://thoughts-on-java.org/entities-dtos-use-projection/ 作者: Thorben Janssen 译者:Yunooa

    76520

    VO,DTO,PO 的见解

    1.VO,DTO,PO的概念 VO 是Value Object 的缩写,值对象,位于视图层,每一个字段与视图层所需要的字段对应 DTO是Data Transfer Object 的缩写,数据传输对象 只有“年龄大于20的才能存入数据库” 这个时候,就要用到VO了 我们要先从页面上拿到VO,然后判断VO中的age是不是大于20,如果大于20,就把VO中的username和password拿出来,放到DTO 中,然后在把DTO中的username和password原封不动地放入PO中,然后将PO传入数据库,这就是他们三个的区别 PS:VO对应于页面上需要显示的数据,PO对应于数据库中存储的数据,DTO对应于除二者之外需要进行传递的数据 ,DTO只是VO到PO,或者PO到VO的中间过程,如果没有这个过程,你仍然可以做到增删改查,这个就根据具体公司来的 过程: 下面以一个时序图建立简单模型来描述上述对象在三层架构应用中的位置 用户发出请求 展示层把VO转换为服务层对应方法所要求的DTO,传送给服务层。 服务层首先根据DTO的数据构造(或重建)一个DO,调用DO的业务方法完成具体业务。

    12041

    DTO与值对象和POJO比较

    本文想澄清DTO与Value Object与POCO的区别,其中DTO代表数据传输对象,而POCO是Plain Old CLR Object,在Java环境中也称为POJO。 DTO,Value Object和POCO等概念经常互换使用。但他们真的是同义词吗? DTO是一个代表一些没有逻辑的数据的类:DTO通常用于在单个应用程序中的不同应用程序或不同层之间传输数据。 POCO(Plain Old CLR Object)是一个术语,类似POJO,因为“POJO”本身不能在.NET中使用,因为其中的字母“J”代表“Java”。因此,POCO具有与POJO相同的语义。 DTO vs Value Object vs POCO:相关性 DTO和Value Object代表不同的概念,不能互换使用。另一方面,POCO是DTO和Value Object的超集。 这取决于天气与否POCO是DTO。 总结 以下内容总结这个主题: 1、DTO!=价值对象 2、DTO⊂POCO 3、值对象⊂POCO

    88320

    Java中 VO、 PO、DO、DTO、 BO、 QO、DAO、POJO的概念

    可以看成是与数据库中的表相映射的 java 对象。最简单的 PO 就是对应数据库中某个表中的一条记录,多个记录可以用 PO 的集合。 PO 中应该不包含任何对数据库的操作。 TO(Transfer Object) ,数据传输对象 在应用程序不同 tie( 关系 ) 之间传输的对象 DTO(Data Transfer Object)数据传输对象 这个概念来源于J2EE的设计模式 POJO(plain ordinary java object) 简单无规则 java 对象 纯的传统意义的 java 对象。 就是说在一些 Object/Relation Mapping 工具中,能够做到维护数据库表记录的 persisent object 完全是一个符合 Java Bean 规范的纯 Java 对象,没有增加别的属性和方法 我的理解就是最基本的 Java Bean ,只有属性字段及 setter 和 getter 方法!。

    1.4K100

    多表查询

    8930

    java进阶|MyBatis系列文章(七)多表查询操作

    是一款支持动态sql的半自动化sql的ORM框架,在企业中应用的很多,相比较于Hibernate,JdbcTemplate这样的框架,它有着自己独特的好处所以这篇还是自己去整理一下关于MyBatis框架在支持多表关联操作的编写 dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java import org.apache.ibatis.annotations.Select;import org.springframework.stereotype.Repository; import java.util.List lombok.Builder;import lombok.Data;import lombok.NoArgsConstructor;import lombok.experimental.Accessors; import java.io.Serializable ;import java.util.List; /** * @author wpw */@AllArgsConstructor@NoArgsConstructor@Data@Builder@Accessors

    29820

    DTO到entity自动赋值

    实体与Dto自动赋值 在开发的过程中,实体之间相互赋值是很正常的事,但是我们一般的方法都通过set和get方法来进行的,如果要赋值的字段少那还行,但是需要赋值的字段超过10个,那就是个灾难,你会看到整屏代码中全是 两个实体属性字段几乎完全相同 两个字体有部分字段相同 源实体只有部分字段赋值,目标实体有完整的值 第一种情况 对于第1点来说,我们用到最多的就是entity和dto之间的转换了,这个我们可以使用Spring outJson = objectMapper.writeValueAsString(productDetail); //上面代码里,outJson的值将会过滤掉只有默认值的属性 第三种情况 本情况主要对于从dto

    46630

    DTO 的替代品!!

    由于每次调用的大部分成本都与客户端和服务器之间的往返时间有关,因此减少调用次数的一种方法是使用一个对象(DTO)来聚合本应传输的数据由几个呼叫,但仅由一个呼叫提供服务。 但是,传统的 DTO 流程还有其他替代方案: 从服务层返回一个业务对象 请注意,我之前从事的项目,我们直接将 BO 映射到从数据库读取的实体。 将 BO 转换为表示层中的 DTO 从表示层返回 DTO 1 返回实体本身 当实体的属性是需要显示的属性的超集时,不需要聚合其他属性。将实体转换为 DTO 不仅是矫枉过正。它会阻碍性能。 5 结论 当业务模型和演示模型之间存在差距时,很容易回到古老的“模式”,例如 DTO。但是,上述任何替代方案都可能更相关。

    10530

    Java DO到DTO转换工具类和BeanUtils.copyProperties()

    项目中需要使用对象(DO)属性赋值给包含其属性子集的对象(DTO)或者显示层对象(VO)。 这种场景下需要大量调用get set方法,当属性较多时代码量较大而且非常繁琐。 import java.lang.reflect.Field; import java.util.Set; import java.util.stream.Collectors; import java.util.stream.Stream

    42410

    Java反射+注解实现Entity类与Dto类相互转换

    整体实现三步骤: 自定义注解 工具类方法实现反射 使用(测试) 1、自定义注解 import java.lang.annotation.*; @Target({ElementType.FIELD, 2、工具类方法实现 import java.lang.reflect.Field; import java.lang.reflect.Method; import java.sql.Timestamp; import java.util.Date; import org.apache.commons.lang.StringUtils; import com.ctccbs.common.annotation.RelMapper false : Dto To Entry * Rule: * 实现相互转换前提: Dto field name(dto和entry的field name相同并且 1)Entity类 与 Dto类对应 ?

    71520

    【Spring Boot + Kotlin 实战教程】Spring Data JPA 多表关联查询 映射到 Dto 的方法【Spring Boot + Kotlin 实战教程】Spring Data

    【Spring Boot + Kotlin 实战教程】Spring Data JPA 多表关联查询 映射到 Dto 的方法 TechArticle package com.ak47.cms.cms.entity import java.util.* import javax.persistence.* @Entity @Table(indexes = arrayOf( Index(name gmtCreate = Date() var gmtModified = Date() } TechArticleTag package com.ak47.cms.cms.entity import java.util strategy = GenerationType.IDENTITY) var id: Long = -1 var tagId = -1 // 文章标签:例如 Kotlin,Java java.util.* class TechArticleDto : TechArticle { var tagDetail = "" constructor(

    18110

    VO、DTO、BO、PO、DO区别

    DTO:(Data Transfer Object)数据传输对象, 即RPC 接口请求或传输出去的对象,用于展示层与服务层之间的数据传输对象。 DO:(Domain Object)领域对象,就是从现实世界中抽象出来的有形或无形的业务实体,可以当成BO;(Data Object)数据层对象,对象属性与数据库字段形成映射关系,可以当成PO VO与DTO DTO:业务逻辑层需要接收的数据和返回的数据。 VO与DTO的属性值基本相同,但是VO是DTO的最终解释,可以对DTO的字段进行适当删减。 : VO中返回的字段为: { "sex": "女演员", } 例子2: DTO: { "sex": "男", "age": "17" } 如果说展示层只需要展示是否成年: VO: DO:一般是PO的组合,也就是多表联查的映射。

    72570

    hibernate多表查询

    这里我们要从区域方来添加街道中的数据,所以我们把这里改成inverse="false" 多表查询(查询出所有区域对应的街道的信息) dao: public List<Jiedao> getAllJiedao

    18520

    多表连接查询

    一、多表连接查询概述 1.1、什么是多表查询 连接是在多个表之间通过一定的连接条件,使表之间发生关联,进而能从多个表之间获取数据。 这样我们在查询我们需要的信息的时候就应用了多表。所以这就是我们的多表查询。 1.2、多表查询的作用 比如: 我们想查询员工A的名字和他所在的部门的名字,则需要使用多表查询。 这就是多表查询的作用。 1.3、多表查询分类 多表查询可以分为二类查询: **内连接:**隐匿内连接、显示内连接 **外连接:**左外连接、右外连接 1.4、笛卡尔积现象 1.4.1、数据准备 创建表和数据 #部门表 create

    9020

    MyBatis注解(多表

    1、多表关系映射说明 1.1、一对一 @One 注解(一对一) 代替了标签,是多表查询的关键,在注解中用来指定子查询返回单一对象。 @One 注解属性介绍: select指定用来多表查询的sqlmapper fetchType会覆盖全局的配置参数 lazyLoadingEnabled 使用格式: @Result(column=" “ ,property=”",one=@One(select="")) 1.2、一对多 @Many 注解(多对一) 代替了标签,是是多表查询的关键,在注解中用来指定子查询返回对象集合。 需要指定映射的 Java 实体类的属性,属性的 javaType(一般为 ArrayList)但是注解中可以不定义; 2、一对一 2.1、需求分析 查询学生信息,加载该学生的班级信息 2.2、编写Classes.java ; import java.io.InputStream; import java.util.List; public class MbClassesTest { private InputStream

    3710

    第五章:使用QueryDSL与SpringDataJPA实现查询返回自定义对象

    在我们实际项目开发中,往往会遇到一种多表关联查询并且仅需要返回多表内的几个字段最后组合成一个集合或者实体。 .dto; import lombok.Data; import java.io.Serializable; /** * 商品dto * ======================== * ; import java.util.stream.Collectors; /** * 多表查询返回商品dto控制器 * ======================== * Created with ,这样就会自动映射到DTO实体内。 QueryDSL & Collection 下面我们采用java8新特性返回自定义结果集,我们查询仍然采用QueryDSL形式,方法代码如下所示: /** * 使用java8新特性Collection

    2.1K40

    相关产品

    • TDSQL-A PostgreSQL 版

      TDSQL-A PostgreSQL 版

      TDSQL-A for PostgreSQL,腾讯云自研的新一代分析型数据库,全面兼容PostgreSQL语法,高度兼容Oracle语法,支持行列混合存储,提供高性能海量数据实时存储和高效复杂查询分析能力。适用GB~PB级数据OLAP处理能力。

    相关资讯

    热门标签

    活动推荐

    扫码关注腾讯云开发者

    领取腾讯云代金券