JPA QL“IN”集合不适用于 openjpa 1.2.2

发布于 2024-11-05 21:37:18 字数 713 浏览 3 评论 0原文

JPA 1 与 OpenJPA 1.2.2 位于单元测试支持的 Hsqldb 1.8 中。以下 JPA QL 不适用于 ids 列表上的“IN”。

@Transactional
public void updateSettlementId(List<Long> voucherIds, Long settlementId) {
    String query = "UPDATE VoucherProcessed vp SET vp.settlement.id=:settlementId where vp.voucher.id IN (:voucherIds)";
    em.createQuery(query).setParameter("settlementId", settlementId)
            .setParameter("voucherIds", StringUtils.join(voucherIds.iterator(), ","))
            .executeUpdate();
}

java.sql.SQLException:在语句中找不到表 [UPDATE VOUCHER_PROCESSED t0 SET t1.settlement_id = ? WHERE (t0.voucher_id IN (?))]

VOUCHER_PROCESSED 表在运行测试时在 hsqldb 中创建,因此上述错误似乎是错误且具有误导性的。

建议?

JPA 1 with OpenJPA 1.2.2 in a unit-test backed Hsqldb 1.8. The following JPA QL doesn't work with a "IN" on a List of ids doesn't work.

@Transactional
public void updateSettlementId(List<Long> voucherIds, Long settlementId) {
    String query = "UPDATE VoucherProcessed vp SET vp.settlement.id=:settlementId where vp.voucher.id IN (:voucherIds)";
    em.createQuery(query).setParameter("settlementId", settlementId)
            .setParameter("voucherIds", StringUtils.join(voucherIds.iterator(), ","))
            .executeUpdate();
}

java.sql.SQLException: Table not found in statement [UPDATE VOUCHER_PROCESSED t0 SET t1.settlement_id = ? WHERE (t0.voucher_id IN (?))]

VOUCHER_PROCESSED table is being created in hsqldb while the test is run so the above error seems erroneous and misleading.

Suggestions?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

糖果控 2024-11-12 21:37:18

试试这个:

  .setParameter("voucherIds", voucherIds)

适用于 Hibernate,但是(如果我错了,请纠正我)JPA 规范不允许 define IN 构造 允许在 setParameter()< 中使用集合/code> 对于像“IN (:voucherIds)”这样的查询,它是特定于供应商的。

Try this:

  .setParameter("voucherIds", voucherIds)

works with Hibernate, but (please correct me if I'm wrong) JPA specification does not define IN construct allow using collection in setParameter() for queries like "IN (:voucherIds)", it is vendor specific.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文