hibernate选择所有投影组
在hibernate Criteria规范中,如果我想在表中对属性进行分组,我必须使用Projections.groupProperty。 问题是我无法选择表中的所有字段。
我想要的是:
SELECT * FROM entity GROUP BY字段
如果我在hibernate Criteria中使用group,那么groupProperty必须存在,并且sql结果将是:SELECT field FROM entity GROUP BY field。
有什么办法可以得到我想要的东西吗? 我在hibernate代码中看到,在CriteriaJoinWalker中,当我想选择all(select *)时,代码已经指定是否有投影。 我的假设是,如果我想改变行为,我必须更改CriteriaJoinWalker代码。 我可以修改代码,也许我可以得到我想要的结果,但如果可以的话,我不想将hibernate核心代码覆盖到我的项目中。 有没有办法在不更改hibernate代码的情况下直接更改它?
// CriteriaJoinWalker if(translator.hasProjection()) { resultTypes = translator.getProjectedTypes(); initProjection(translator.getSelect(), translator.getWhereCondition(), translator.getOrderBy(), translator.getGroupBy(), LockMode.NONE); } else { resultTypes = (new Type[] { TypeFactory.manyToOne(persister.getEntityName()) }); initAll(translator.getWhereCondition(), translator.getOrderBy(), LockMode.NONE); }
谢谢
如果您使用Projections,那么您将无法获得整个Entity对象。 不幸的是,冬眠无法帮助你。 查看此问题并查看此主题 。
- Hibernate会话线程安全
- Hibernate中的小写注释
- JPA插入父/子会导致MySQLIntegrityConstraintViolationException
- Spring Boot 1.2.5 Hibernate JPA嵌套了很多对很多关系
- org.hibernate.LazyInitializationException:无法初始化代理 – 没有会话?
- 使用Tomcat和gradle进行Hibernate
- 如何使用JPA(Hibernate)创建与同一实体的关系?
- 使用persistence.xml时将Hibernate 4.0与Tomcat 7一起使用时出现JndiException
- 从POJO获取带注释的hibernate tablename