java getresultlist_java – JPA query.getResultList()?

我使用JPA 1.0:

Query query;

query = em.createNamedQuery("getThresholdParameters");

query.setParameter(1, Integer.parseInt(circleId));

List resultList = new ArrayList();

resultList = query.getResultList();

这里我得到了List< Object []>的结果,因此我必须键入将该行的所有参数转换为它们各自的类型,这很麻烦.

在JPA 2.0中,有TypedQuery返回类型为1的实体对象指定.

但是当我使用JPA 1时,我无法使用它.

如何获得结果作为我想要的类型的实体对象?

编辑:

QUERY

@Entity

@Table(name="GMA_THRESHOLD_PARAMETERS")

@NamedQuery(

name = "getThresholdParameters",

query = "select gmaTh.minNumberOc, gmaTh.minDurationOc, gmaTh.maxNumberIc, gmaTh.maxDurationIc, gmaTh.maxNumberCellId,"

+ "gmaTh.distinctBnumberRatio, gmaTh.minPercentDistinctBnumber from GmaThresholdParameter gmaTh "

+ "where gmaTh.id.circleId=?1 AND gmaTh.id.tspId=?2 AND gmaTh.id.flag=?3 "

)

解决方法:

您的查询选择了许多字段.这样的查询总是返回Object数组的列表.如果您想要一个包含GmaThresholdParameter实体实例的列表,那么查询应该是

select gmaTh from GmaThresholdParameter gmaTh

where gmaTh.id.circleId=?1 AND gmaTh.id.tspId=?2 AND gmaTh.id.flag=?3

然后,获取实体列表的代码将是

List resultList = query.getResultList();

您将从编译器获得类型安全警告,您可以忽略.

标签:java,jpa,persistence,java-ee

来源: https://codeday.me/bug/20191003/1846463.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值