首页 文章

hibernate选择所有投影组

提问于
浏览
3

在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);
    }

谢谢

1 回答

  • 1

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

相关问题