Hibernate Criteria API相当于HQL select子句?
我想对两个持久化类进行组合查询。
在HQL中,这可以通过select子句来实现,
select new Family(mother, mate, offspr) from DomesticCat as mother join mother.mate as mate left join mother.kittens as offspr
在上面的例子中,Family是一个联合类,DemesticCat作为它的construtor params
什么是HQL select子句的Criteria等价物?
您必须为此使用ResultTransformer
。 Hibernate 3.2:HQL和SQL博客文章的变形金刚给出了以下示例(其中StudentDTO
是非实体Bean):
List resultWithAliasedBean = s.createCriteria(Enrolment.class) .createAlias("student", "st").createAlias("course", "co") .setProjection( Projections.projectionList() .add( Projections.property("st.name"), "studentName" ) .add( Projections.property("co.description"), "courseDescription" ) ) .setResultTransformer( Transformers.aliasToBean(StudentDTO.class) ) .list(); StudentDTO dto = (StudentDTO)resultWithAliasedBean.get(0);
在Criteria API中,此function由Projections处理。 文档有点令人困惑和过于复杂,但这是你需要看到的。
- 与Bean Validation API结合使用时,Hibernate不遵循JPA规范吗?
- java.lang.IllegalArgumentException“无法使用Spring 4和Hibernate 4设置DAO字段”
- 如何在hibernate中保留实体期间validation实体上的约束
- Hibernate Criteria API中的SQL’LIKE’运算符
- 使用getCurrentSession()时获取“找不到当前线程的会话”exception
- 为什么要使用实体经理?
- 只有在第二次尝试后,maven安装抛出“打开zip文件时出错”
- Hibernate QueryTranslatorImpl HQL AST解析性能
- Hibernate @Transactional Sessions