学习记录687@spring data jpa 动态传递list参数并判断list是否为空

实际应用中需要在spring data jpa中使用原生sql,传递的参数是list,要根据list判断是否为空来判断是否要使用这个参数。

尝试了很多方法,比如size、length、is null、!=null等等,都要报错,比如could not extract ResultSet; SQL [n/a]; nested exception is org.hibernate.exception.DataException: could not extract ResultSet 错误。

最后查阅网上文章使用如下方式得到了正确的结果。

java 复制代码
@Query("SELECT *  FROM order \n" +
       "WHERE" +
       "(COALESCE(?1) IS NULL OR (id IN ?1))")
List<Order> getOrders(List<Long> ids);

这里的关键是COALESCE函数,此函数表示传进去的list的值判断,返回第一个不为null的值,如果list为空则返回null。这样就相当于对list进行判断并执行id IN了。

相关推荐
VelinX15 小时前
【个人学习||算法】贪心算法
学习·算法·贪心算法
烤麻辣烫15 小时前
I/O流 进阶流
java·开发语言·学习·intellij-idea
硅基流动15 小时前
硅基流动 × DeepStudent:内置 10+ 项技能,开源 AI 学习智能体
人工智能·学习
不灭锦鲤15 小时前
网络安全学习第162天
学习·安全·web安全
承渊政道15 小时前
【优选算法】(实战掌握分治思想的使用方法)
数据结构·c++·笔记·vscode·学习·算法·leetcode
marsh020615 小时前
23 openclaw防止SQL注入:参数化查询与ORM安全使用
数据库·sql·安全·ai·编程·技术
qq_5710993515 小时前
学习周报三十八
学习
我的xiaodoujiao16 小时前
API 接口自动化测试详细图文教程学习系列8--测试接口
python·学习·测试工具·pytest
小江的记录本16 小时前
【端口号】计算机领域常见端口号汇总(完整版)
java·前端·windows·spring boot·后端·sql·spring
yv_3016 小时前
CTF-IDA
学习·ctf