gpt4 book ai didi

java - hibernate 选择所有投影分组依据

转载 作者:塔克拉玛干 更新时间:2023-11-02 20:16:21 25 4
gpt4 key购买 nike

在 hibernate Criteria 规范中,如果我想对表中的属性进行分组,我必须使用 Projections.groupProperty。问题是我无法选择表中的所有字段。

我想要的是:

SELECT * FROM entity GROUP BY 字段

如果我在 hibernate Criteria 中使用 group,那么 groupProperty 必须存在,sql 结果将是:从实体 GROUP BY 字段中选择字段。

有什么办法可以得到我想要的吗?我在 hibernate 代码中看到,在 CriteriaJoinWalker 中,当我想全选 (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);
}

谢谢

最佳答案

如果您使用投影,那么您将无法获得一个实体对象作为一个整体。不幸的是 hibernate 不能帮助你。看看这个 Issue并查看此 thread .

关于java - hibernate 选择所有投影分组依据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6678216/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com