Hibernate选择所有投影,按分组进行

3
在hibernate Criteria规范中,如果我想在表中分组属性,则必须使用Projections.groupProperty。问题是我无法选择表中的所有字段。
我想要的是: SELECT * FROM entity GROUP BY field
如果我在hibernate Criteria中使用group,则必须存在groupProperty,并且SQL结果将为: SELECT field FROM entity GROUP BY field。
有没有办法得到我想要的结果?我在hibernate代码中看到,在CriteriaJoinWalker中,当我想要选择全部(select *)时,代码已经指定了是否有projection。我的假设是,如果我想改变行为,我必须改变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个回答

1

如果您使用投影,则无法获取整个实体对象。不幸的是,Hibernate 无法帮助您。请查看此 问题 和这个 线程


是的,我知道...就像我之前说过的一样。似乎没有办法从投影中获取实体。 - Jef

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接