JPA通过SqlResultSetMapping和NamedNativeQuery实现DTO

栏目: Java · 发布时间: 6年前

内容简介:获取超出你实际需要的数据容易导致性能损失。使用DTO可以让我们只提取所需的数据。在这里我们展示依赖SqlResultSetMapping,NamedNativeQuery和EntityManager实现DTO。假设需要从实体Car中获取name和color两项数据的CarDto,Car代码如下,在其中使用了注释@SqlResultSetMapping,@NamedNativeQuery:CarDto代码:

获取超出你实际需要的数据容易导致性能损失。使用DTO可以让我们只提取所需的数据。在这里我们展示依赖SqlResultSetMapping,NamedNativeQuery和EntityManager实现DTO。

假设需要从实体Car中获取name和color两项数据的CarDto,Car代码如下,在其中使用了注释@SqlResultSetMapping,@NamedNativeQuery:

@NamedNativeQuery(
        name=<font>"CarDto"</font><font>,
        query=</font><font>"select name, color from car"</font><font>,
        resultSetMapping=</font><font>"CarDto"</font><font>
)
@SqlResultSetMapping(
        name=</font><font>"CarDto"</font><font>,
        classes=@ConstructorResult(
                targetClass=CarDto.<b>class</b>,
                columns={
                    @ColumnResult(name=</font><font>"name"</font><font>),
                    @ColumnResult(name=</font><font>"color"</font><font>)
                }                
        )
)
@Entity
@Table(name = </font><font>"car"</font><font>)
<b>public</b> <b>class</b> Car implements Serializable {

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

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    <b>private</b> Long id;

    <b>private</b> String name;
    <b>private</b> String engine;
    <b>private</b> String color;
</font>

CarDto代码:

<b>public</b> <b>class</b> CarDto 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> CarDto(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>"CarDto{"</font><font> + </font><font>"name="</font><font> + name + </font><font>", color="</font><font> + color + '}';
    }        
}
</font>

第二步,编制DTO调用EntityManager的createNameQuery返回CarDto的List:

@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;

    @Override
    <b>public</b> <S <b>extends</b> T> S persist(S entity) {
        
        Objects.requireNonNull(entity, <font>"Cannot persist a null entity"</font><font>);
        
        entityManager.persist(entity);

        <b>return</b> entity;
    }

    @Transactional(readOnly=<b>true</b>)
    <b>public</b> List<CarDto> fetchCars() {
        Query query = entityManager.createNamedQuery(</font><font>"CarDto"</font><font>);                
        List<CarDto> result = query.getResultList();

        <b>return</b> result;
    }

    <b>protected</b> EntityManager getEntityManager() {
        <b>return</b> entityManager;
    }
}

Service调用:
</font>
@Service
<b>public</b> <b>class</b> CarService {

    <b>private</b> <b>final</b> Dao dao;

    <b>public</b> CarService(Dao dao) {
        <b>this</b>.dao = dao;
    }

   
    <b>public</b> List<CarDto> fetchCars() {
        <b>return</b> dao.fetchCars();
    }
}

也可以使用Spring data project投影实现获取DTO,参考 https://www.jdon.com/51628


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

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

Web界面设计

Web界面设计

Bill Scott、Theresa Neil / 李松峰 / 电子工业出版社 / 2009年7月 / 80.00元

当前的Web已经进入崭新的时代!本书涵盖了在基于独一无二的Web环境下、在创建丰富体验的过程中设计Web界面的最佳实践、模式和原理。UI专家Bill Scott和Theresa Neil在他们多年实践经验和不懈探索的基础上,总结提炼出了Web界面设计的六大原理——直截了当、简化交互、足不出户、提供邀请、使用变换和即时反应,并以这六大原理为依托,以当今Web上各类开风气之先的流行网站为示例,向读者展......一起来看看 《Web界面设计》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

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

RGB CMYK 互转工具