【发布时间】:2011-10-04 10:15:09
【问题描述】:
在hibernate Criteria规范中,如果我想在表格中对属性进行分组,我必须使用Projections.groupProperty。问题是我无法选择表格中的所有字段。
我想要的是:
SELECT * FROM entity GROUP BY 字段
如果我在hibernate Criteria中使用group,那么groupProperty必须存在,sql结果为: SELECT field FROM entity GROUP BY field。
有什么方法可以得到我想要的吗?我在休眠代码中看到,在 CriteriaJoinWalker 中,当我想全选(选择 *)时,代码已经指定是否有投影。我假设如果我想改变行为,我必须改变 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);
}
谢谢
【问题讨论】: