内容简介:获取超出需要的数据更容易导致性能损失。使用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>
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- ios原生二维码扫描和生成
- 回到基础:如何用原生 DOM API 生成表格
- 零信任原生安全:超越云原生安全
- 畅谈云原生(下):云原生的飞轮理论
- 【云原生丨主题周】云原生为何物?为何重要?
- Micronaut 2.0.0 发布,原生云原生微服务框架
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Android和PHP开发最佳实践
黄隽实 / 机械工业出版社华章公司 / 2013-3-20 / 79.00元
本书是国内第一本同时讲述Android客户端开发和PHP服务端开发的经典著作。 本书以一个完整的微博应用项目实例为主线,由浅入深地讲解了Android客户端开发和PHP服务端开发的思路和技巧。从前期的产品设计、架构设计,到客户端和服务端的编码实现,再到性能测试和系统优化,以及最后的打包发布,完整地介绍了移动互联网应用开发的过程。同时,本书也介绍了Android系统中比较有特色的功能,比如Go......一起来看看 《Android和PHP开发最佳实践》 这本书的介绍吧!