java - 如何使用 jpa 和 hibernate 将 native 查询映射到 POJO 类

标签 java hibernate jpa pojo

我在我的项目中同时使用 JPA 和 hibernate。

我创建了一个查询,在其中对许多表进行了联接操作。所以我创建了一个本地的。我得到的结果位于 object[] 列表中,但我希望结果自动转换为 java POJO 类。 您可以在下面检查查询语法和 POJO java 类。

JPA 查询

@Query(value = "SELECT obsp.Identifier, obs.phenomenontimestart, nv.value " +
        "From Series s " +
        "INNER JOIN Featureofinterest fi on s.featureofinterestid = fi.featureofinterestid " +
        "INNER JOIN ObservableProperty obsp on s.observablepropertyid = obsp.ObservablePropertyId " +
        "INNER JOIN Observation obs on s.seriesid = obs.seriesid " +
        "INNER JOIN NumericValue nv on nv.observationid = obs.observationid " +
        "where fi.identifier = ?1 and obs.phenomenontimestart >= ?2 AND obs.phenomenontimestart <= ?3 " +
        "order by obs.phenomenontimestart",
        nativeQuery = true)
List<CurrentMeasure> findCurrentMeasure(String ident, Timestamp t1, Timestamp t2);

POJO类

public class CurrentMeasure {

private String identifier;
private Timestamp dateTime;
private BigDecimal bigDecimal;

public CurrentMeasure() {
}

public CurrentMeasure(String identifier, Timestamp dateTime, BigDecimal bigDecimal) {
    this.identifier = identifier;
    this.dateTime = dateTime;
    this.bigDecimal = bigDecimal;
}

public String getIdentifier() {
    return identifier;
}

public void setIdentifier(String identifier) {
    this.identifier = identifier;
}

public Timestamp getDateTime() {
    return dateTime;
}

public void setDateTime(Timestamp dateTime) {
    this.dateTime = dateTime;
}

public BigDecimal getBigDecimal() {
    return bigDecimal;
}

public void setBigDecimal(BigDecimal bigDecimal) {
    this.bigDecimal = bigDecimal;
}

}

最佳答案

使用 JPA,您可以调用类的构造函数 CurrentMeasure直接在 HQL 查询中。

示例: SELECT NEW <package>.CurrentMeasure(obsp.Identifier, obs.phenomenontimestart, nv.value) FROM ...

新语法在Jboss documentation中进行了解释。参见第 11.5 章。

另一个解决方案是使用 HQL Transformers无需借助构造函数即可获得相同的结果。

关于java - 如何使用 jpa 和 hibernate 将 native 查询映射到 POJO 类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39155529/

相关文章:

java - org.hibernate.criterion.Order 无法解析字符串的 '.' 属性

java - 创建 EnityManagerFactory 时出现 NullPointerException

java - 将密码传递给junitcore

java - 使用Hibernate技术在JAVA中按字母顺序对Jtree进行排序

java - 如何使用 Hibernate 表示遗留数据库?

java - 强制 hibernate 将 id 留空

java - 更新实体时的JPA

java - 使用 jaxb 类作为 Web 方法的参数或结果

java - 无法在 NetBeans 或 Eclipse 中从 wsdl 生成代理类

hibernate - 如何在grails中缓存(整个表或Domain.list()方法的结果)?