如何通过ResultTransformer和原生SQL或JPQL生成DTO?

栏目: 数据库 · 发布时间: 6年前

内容简介:获取超出需要的数据更容易导致性能损失。使用DTO可以让我们只提取所需的数据。在这个应用程序中,我们依赖于Hibernate ResultTransformer和原生SQL生成DTO?对于不可变的DTO值对象和可变的DTO对象使用不同的方式,不可变的DTO值对象是final字段,因此不能有setter字段:可变的DTO对象:

获取超出需要的数据更容易导致性能损失。使用DTO可以让我们只提取所需的数据。在这个应用程序中,我们依赖于Hibernate ResultTransformer和原生 SQL 生成DTO?

对于不可变的DTO值对象和可变的DTO对象使用不同的方式,不可变的DTO值对象是final字段,因此不能有setter字段:

<b>public</b> <b>class</b> CarDtoNoSetters implements Serializable {

    <b>private</b> <b>static</b> <b>final</b> <b>long</b> serialVersionUID = 1L;

    <b>private</b> <b>final</b> String name;
    <b>private</b> <b>final</b> String color;       

    <b>public</b> CarDtoNoSetters(String name, String color) {
        <b>this</b>.name = name;
        <b>this</b>.color = color;
    }

    <b>public</b> String getName() {
        <b>return</b> name;
    }

    <b>public</b> String getColor() {
        <b>return</b> color;
    }            

    @Override
    <b>public</b> String toString() {
        <b>return</b> <font>"CarDtoNoSetters{"</font><font> + </font><font>"name="</font><font> + name + </font><font>", color="</font><font> + color + '}';
    }           
}
</font>

可变的DTO对象:

<b>public</b> <b>class</b> CarDtoWithSetters implements Serializable {

    <b>private</b> <b>static</b> <b>final</b> <b>long</b> serialVersionUID = 1L;
    
    <b>private</b> String name;
    <b>private</b> String color;    

    <b>public</b> String getName() {
        <b>return</b> name;
    }

    <b>public</b> <b>void</b> setName(String name) {
        <b>this</b>.name = name;
    }

    <b>public</b> String getColor() {
        <b>return</b> color;
    }

    <b>public</b> <b>void</b> setColor(String color) {
        <b>this</b>.color = color;
    }          

    @Override
    <b>public</b> String toString() {
        <b>return</b> <font>"CarDtoWithSetters{"</font><font> + </font><font>"name="</font><font> + name + </font><font>", color="</font><font> + color + '}';
    }        
}
</font>

编写自己的DAO类,对于不可变的DTO值对象使用ResultTransformer+AliasToBeanConstructorResultTransformer,可变的使用ResultTransformer+Transformers.aliasToBean():

@Repository
@Transactional
<b>public</b> <b>class</b> Dao<T, ID <b>extends</b> Serializable> implements GenericDao<T, ID> {
    
    @PersistenceContext
    <b>private</b> EntityManager entityManager;

    
    @Transactional(readOnly = <b>true</b>)
    <b>public</b> List<CarDtoNoSetters> fetchCarsNoSetters() {
        Query query = entityManager
                .createNativeQuery(<font>"select name, color from car"</font><font>)
                .unwrap(org.hibernate.query.NativeQuery.<b>class</b>)
                .setResultTransformer(
                        <b>new</b> AliasToBeanConstructorResultTransformer(
                                CarDtoNoSetters.<b>class</b>.getConstructors()[0]
                        )
                );
        
        List<CarDtoNoSetters> result = query.getResultList();
        
        <b>return</b> result;
    }
    
    @Transactional(readOnly = <b>true</b>)
    <b>public</b> List<CarDtoWithSetters> fetchCarsWithSetters() {
        Query query = entityManager
                .createNativeQuery(</font><font>"select name, color from car"</font><font>)
                .unwrap(org.hibernate.query.NativeQuery.<b>class</b>)
                .setResultTransformer(
                        Transformers.aliasToBean(CarDtoWithSetters.<b>class</b>)
                );        

        List<CarDtoWithSetters> result = query.getResultList();
        
        <b>return</b> result;
    }    
    
    <b>protected</b> EntityManager getEntityManager() {
        <b>return</b> entityManager;
    }
}
</font>

使用EntityManager.createNativeQuery()和unwrap(org.hibernate.query.NativeQuery.class)- 从Hibernate 5.2开始,ResultTransformer不推荐使用,但是直到可以使用替换(在Hibernate 6.0中)它可以使用( 进一步阅读

使用JPQL和原生SQL在SQL语句上稍微有点不同:

   @Transactional(readOnly = <b>true</b>)
    <b>public</b> List<CarDtoNoSetters> fetchCarsNoSetters() {
        Query query = entityManager
                .createQuery(<font>"select c.name as name, c.color as color from Car c"</font><font>)
                .unwrap(org.hibernate.query.Query.<b>class</b>)
                .setResultTransformer(
                        <b>new</b> AliasToBeanConstructorResultTransformer(
                                CarDtoNoSetters.<b>class</b>.getConstructors()[0]
                        )
                );
        
        List<CarDtoNoSetters> result = query.getResultList();
        
        <b>return</b> result;
    }
    
    @Transactional(readOnly = <b>true</b>)
    <b>public</b> List<CarDtoWithSetters> fetchCarsWithSetters() {
        Query query = entityManager
                .createQuery(</font><font>"select c.name as name, c.color as color from Car c"</font><font>)
                .unwrap(org.hibernate.query.Query.<b>class</b>)
                .setResultTransformer(
                        Transformers.aliasToBean(CarDtoWithSetters.<b>class</b>)
                );        

        List<CarDtoWithSetters> result = query.getResultList();
        
        <b>return</b> result;
    }    
</font>

原生SQL

JPQL源码


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

JSP网站开发典型模块与实例精讲

JSP网站开发典型模块与实例精讲

李振捷 / 电子工业出版社 / 2006-8 / 50.0

本书是典型模块与实例精讲丛书中的一本。 本书讲解了使用JSP开发网站系统的经典模块和工程实例,基本囊括了JSP的重点技术,对这些模块稍加修改就可以直接使用到实际项目中。为了方便本书的读者交流在学习中遇到的问题,特地在本书的服务网站上公布了很多QQ群组,读者只要拥有QQ号码,就可以参与到本书的QQ学习群组中一起讨论学习心得。本书的作者还在一定的时间给读者提供在线答疑服务。一起来看看 《JSP网站开发典型模块与实例精讲》 这本书的介绍吧!

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具