进行了一些谷歌搜索后,这似乎是不可能的 - Hibernate 只允许{alias}
在SQLProjection
. 然而,我确实发现了这个关于Hibernate JIRA 页面限制的问题。
有人通过一个新类提交了一个允许在SQLProjection
字符串中使用非根别名的补丁。RestrictionsExt
使用我在问题中的示例:
Projections.sqlProjection("MIN(i.powerRestarts) as value", new String[]{"value"}, new Type[]{new LongType()}))
i
现在可以将别名引用为:
RestrictionsExt.sqlProjection("MIN({i}.powerRestarts) as value", "value", new LongType())
我不得不修改静态RestrictionsExt.sqlProjection
方法以允许指定列别名 ( "value"
) 的类型(此处定义为LongType
),因为补丁不允许这样做并且默认为StringType
.
补丁中的 SQLAliasedProjection 类还需要访问org.hibernate.loader.criteria.CriteriaQueryTranslator
:getOuterQueryTranslator
和中的以下私有方法getAliasedCriteria
。为了在不修改 Hibernate 源的情况下使其工作,我使用了反射:
cri = ((org.hibernate.loader.criteria.CriteriaQueryTranslator) criteriaQuery).getAliasedCriteria(alias);
改为:
Method m = ((org.hibernate.loader.criteria.CriteriaQueryTranslator) criteriaQuery).getClass().getDeclaredMethod("getAliasedCriteria", String.class);
m.setAccessible(true);
cri = (Criteria) m.invoke(((org.hibernate.loader.criteria.CriteriaQueryTranslator) criteriaQuery), alias);
希望这将帮助其他面临同样问题的人。