java-ee – JPA中的TypedQuery而不是普通的Query

栏目: Java · 发布时间: 5年前

内容简介:翻译自:https://stackoverflow.com/questions/15413434/typedquery-instead-of-normal-query-in-jpa
是否可以将此查询编写为TypedQuery,并让两个Long运行到一个内部有两个公共Long字段的Object中.
Query q = em.createQuery(
            "SELECT c.id, COUNT(t.id) " +
            "FROM PubText t " +
            "JOIN t.comm c " +
            "WHERE c.element = ?1 " +
            "GROUP BY c.id");
    q.setParameter(1, e);
    List<?> rl = q.getResultList();
    Iterator<?> it = rl.iterator();
    HashMap<Long, Long> res = new HashMap<Long, Long>();
    while (it.hasNext()) {
        Object[] n = (Object[]) it.next();
        res.put((Long)n[0], (Long)n[1]);
    }
    return res;

JPA只为此提供了一个功能 – 构造函数表达式:

Query q = entityManager.createQuery("SELECT NEW com.example.DTO( c.id, COUNT(t.id)) FROM ...");
List<DTO> dtos = q.getResultList();

您的DTO课程可以是POJO.它需要的是一个接受2个Longs的公共构造函数.请注意,您必须在NEWoperator之后提供您班级的完全限定名称.

翻译自:https://stackoverflow.com/questions/15413434/typedquery-instead-of-normal-query-in-jpa


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

J语言实用教程

J语言实用教程

杨朝杰 / 电子工业出版社 / 1999-04-01 / 30.0

一起来看看 《J语言实用教程》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

在线进制转换器
在线进制转换器

各进制数互转换器

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换