休眠选择所有投影分组

Posted

技术标签:

【中文标题】休眠选择所有投影分组【英文标题】:hibernate select all projections group by 【发布时间】: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);
    

谢谢

【问题讨论】:

【参考方案1】:

如果您使用 Projections,那么您将无法获得一个整体的 Entity 对象。不幸的是hibernate不能帮助你。查看此Issue 并查看此thread。

【讨论】:

是的,我知道...正如我之前所说。似乎没有办法从 Projections 中获取实体。

以上是关于休眠选择所有投影分组的主要内容,如果未能解决你的问题,请参考以下文章

在 Hibernate 命名查询中根据参数选择分组

我可以在休眠中使用单表继承从扩展实体中选择所有超级对象吗?

带有投影和限制的休眠条件查询问题

休眠条件通过分组计数

休眠标准组结果按日期从时间戳

使用 AliasToBeanResultTransformer 设置的休眠 HQL 投影问题