java - 使用 hibernate 条件选择值对象

标签 java hibernate

我正在尝试找出是否可以使用 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/

相关文章:

java - Glassfish java错误: "Exception while preparing the app"

Java如何使用键绑定(bind)拦截窗口上任何位置的组合键

java - 什么是依赖注入(inject)?

java - Java 中 InputStream 的多个读取器

java - MySQL导入数据到HDFS : ClassNotFoundException

java - 多个JTA事务: no session associated with the current transaction

java - 为什么 Hibernate/JPA 在查询中报告空指针异常?

java - 使用 hibernate 在 JPA 中配置 EntityManager

java - Spring boot的数据库配置需要在web中才能正常工作

database - 使用 interbase 设计数据库表的最佳方法?