内容简介:获取超出需要的数据更容易导致性能损失。使用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>
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
第一本Docker书 修订版
詹姆斯·特恩布尔 (James Turnbull) / 李兆海、刘斌、巨震 / 人民邮电出版社 / 2016-4-1 / CNY 59.00
Docker是一个开源的应用容器引擎,开发者可以利用Docker打包自己的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化。 本书由Docker公司前服务与支持副总裁James Turnbull编写,是Docker开发指南。本书专注于Docker 1.9及以上版本,指导读者完成Docker的安装、部署、管理和扩展,带领读者经历从测试到生产的整个开发生......一起来看看 《第一本Docker书 修订版》 这本书的介绍吧!