hibernate的查询 博客分类: JPA Hibernate hibernate
程序员文章站
2024-03-14 12:37:52
...
刚开始对hibernate jpa不太熟悉,又被sql情有独钟,然后发现jpa查询无法封装到自定义的vo中(这是误区,可以通过jpa查询然后构造函数的形式注入),思前想后,算了,自己封装一个方法直接转成map集合然后封装到集合中。
//实现map到javabean的转换用于兼容hibernate自定义sql封装到bean
public List findPageBeanMapBySQL(String sql, Pageable pageable,Class clazz) {
Query query = entityManager.createNativeQuery(sql);
query.unwrap(SQLQuery.class).setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
if(pageable!=null){
long total = query.getResultList().size();
query.setFirstResult((pageable.getPageNumber() - 1) * pageable.getPageSize());
query.setMaxResults(pageable.getPageSize());
}
List<T> list = query.getResultList();
List lists = Lists.newArrayList();
if(list!=null && list.size()>0){
for(T t:list){
BeanWrapper beanWrapper = new BeanWrapperImpl(clazz);
beanWrapper.setPropertyValues((Map<?, ?>) t);
lists.add( beanWrapper.getWrappedInstance());
}
}
return lists;
}
//实现map到javabean的转换用于兼容hibernate自定义sql封装到bean
public List findPageBeanMapBySQL(String sql, Pageable pageable,Class clazz) {
Query query = entityManager.createNativeQuery(sql);
query.unwrap(SQLQuery.class).setResultTransformer(Transformers.ALIAS_TO_ENTITY_MAP);
if(pageable!=null){
long total = query.getResultList().size();
query.setFirstResult((pageable.getPageNumber() - 1) * pageable.getPageSize());
query.setMaxResults(pageable.getPageSize());
}
List<T> list = query.getResultList();
List lists = Lists.newArrayList();
if(list!=null && list.size()>0){
for(T t:list){
BeanWrapper beanWrapper = new BeanWrapperImpl(clazz);
beanWrapper.setPropertyValues((Map<?, ?>) t);
lists.add( beanWrapper.getWrappedInstance());
}
}
return lists;
}
推荐阅读
-
hibernate的查询 博客分类: JPA Hibernate hibernate
-
hibernate的查询 博客分类: JPA Hibernate hibernate
-
关于jpa查询 博客分类: JPA Hibernate jpa
-
hibernate annotation对jpa主键one-to-one映射关系支持的有问题 HibernateJPAJBoss
-
hibernate annotation对jpa主键one-to-one映射关系支持的有问题 HibernateJPAJBoss
-
hibernate 乐观锁 测试 博客分类: 多线程
-
Hibernate Interceptor(拦截器) 博客分类: Java
-
Hibernate 一对一关系(基于XML) 博客分类: Hibernate hibernate
-
Java Hibernate中使用HQL语句进行数据库查询的要点解析
-
Java Hibernate中使用HQL语句进行数据库查询的要点解析