通过javax.persistence.Tuple原生SQL获取DTO数据

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

内容简介:从实体中获取DTO数据,也就是从DDD聚合中获取DDD值对象有多种方式,如果我们不使用DTO方式,直接返回完整实体聚合,容易导致性能损失,使用DTO可以让我们只提取所需的数据。在这个应用程序中,我们展示如何依赖于javax.persistence.Tuple原生SQL生成DTO。点击#DTO标签可获得更多生成DTO的方式。主要点:编制自己的Dao调用EntityManager.createNativeQuery(),返回java.persistence.Tuple类型:

从实体中获取DTO数据,也就是从DDD聚合中获取DDD值对象有多种方式,如果我们不使用DTO方式,直接返回完整实体聚合,容易导致性能损失,使用DTO可以让我们只提取所需的数据。在这个应用程序中,我们展示如何依赖于javax.persistence.Tuple原生 SQL 生成DTO。点击#DTO标签可获得更多生成DTO的方式。

主要点:

编制自己的Dao调用EntityManager.createNativeQuery(),返回java.persistence.Tuple类型:

假设Car实体:

@Entity
@Table(name = <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>

编制自己的DAO:

@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<Tuple> fetchCars() {
        List<Tuple> result = entityManager
                .createNativeQuery(
                        </font><font>"select name, color from car"</font><font>, Tuple.<b>class</b>
                ).getResultList();

        <b>return</b> result;
    }
</font>

Service调用:

@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<Tuple> fetchCars() {
        <b>return</b> dao.fetchCars();
    }
}

最终Spring Boot中调用:

@SpringBootApplication
<b>public</b> <b>class</b> TupleAndSqlApplication {
    
    <b>private</b> <b>static</b> <b>final</b> Logger logger
            = Logger.getLogger(TupleAndSqlApplication.<b>class</b>.getName());
    
    @Autowired
    <b>private</b> CarService carService;
    
    <b>public</b> <b>static</b> <b>void</b> main(String[] args) {
        SpringApplication.run(TupleAndSqlApplication.<b>class</b>, args);
    }
    
    @Bean
    <b>public</b> ApplicationRunner init() {
        <b>return</b> args -> {
            
            carService.populateCars();
            List<Tuple> cars = carService.fetchCars();
            
            cars.forEach((e) -> logger.info(() -> <font>"Car: "</font><font> + e.get(</font><font>"name"</font><font>) + </font><font>","</font><font> + e.get(</font><font>"color"</font><font>)));
        };
    }
}
</font>

以上所述就是小编给大家介绍的《通过javax.persistence.Tuple原生SQL获取DTO数据》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

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

产品觉醒:产品经理的视角与方法论

产品觉醒:产品经理的视角与方法论

判官(李泽澄) / 电子工业出版社 / 2018-11 / 59.80元

《产品觉醒:产品经理的视角与方法论》是作者多年工作经验的汇集,通过自己亲身经历来对产品运营、行业和人生选择做一个全面的复盘,为读者提供有一定深度的分析。 《产品觉醒:产品经理的视角与方法论》共7章,第1章介绍了产品经理应该具有的视角来分析和观察产品分析方法;第2章介绍了做产品时如何破局来解决相应的问题;第3章介绍了在做产品经理前先分析自己;第4章介绍了怎么来解决执行力的问题;第5章介绍了怎么......一起来看看 《产品觉醒:产品经理的视角与方法论》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

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

在线压缩/解压 CSS 代码

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

Markdown 在线编辑器