我正在尝试找出是否可以使用 Hibernate Criteria API 执行以下 HQL:
String hql = "select new InitialCount(substring(name, 1,1), count(id)) from Person group by substring(name, 1,1)";
InitialCount 是一个非常简单的 bean,带有一个字符串和一个 long 构造器:
public static class InitialCount {
private final String initial;
private final long count;
public InitialCount(String initial, long count) {
this.initial = initial;
this.count = count;
}
}
这可能吗?
最佳答案
试试这个:
criteria.setProjection(Projections.projectionList()
.add(Projections.groupProperty("formulaProp").as("initial"))
.add(Projections.count("id").as("count"))
).setResultTransformer(Transformers.aliasToBean(InitialCount.class)).list();
其中 formulaProp 是用公式“substring(name, 1,1)”映射的 person 的属性
关于java - 使用 hibernate 条件选择值对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3958222/