Spring Data JPA @Query In查询

文章讨论了在JPA中使用@Query注解执行Oracle数据库的原生SQL更新时,如何处理String类型的id集合。最初尝试通过字符串拼接方式构建id列表,但发现无效。后来改用直接传入List参数,JPA能自动处理,证明这种方式可行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

需求用到jpa update 写原生sql 数据库为oracle

有一个参数是String类型的id集合

最开始考虑用字符串拼接的方式将id拼成想象中的样子

// id集合
List<String> ids;
StringBuilder sb = new StringBuilder("(");
ids.forEach(id -> {
    sb.append("'" + id + "'");
    sb.append(",");
});
// 去除最后一个逗号
sb.deleteCharAt(sb.length() - 1);
sb.append(")");
// 拼接结果为 ('id1','id2')

// jpa注解
@Query(nativeQuery = true, value = "update table set column = value where id in :ids")
Integer updateColumn(String ids);

结论为不可行 这个参数没有任何作用

网上找了部分方法  好多都是各种拼接测试内容

最终测试将代码改为

// id集合
List<String> ids;

// jpa注解
@Query(nativeQuery = true, value = "update table set column = value where id in :ids")
Integer updateColumn(List<String> ids);

结论为可行 原来写原生的sql jpa也会帮忙处理下

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值