学习记录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了。

相关推荐
是烟花哈6 小时前
【前端】React框架学习
前端·学习·react.js
檀越剑指大厂6 小时前
32 万星的面试学习计划 + 内网穿透工具,程序员面试准备效率翻倍!
学习·面试·职场和发展
YangYang9YangYan8 小时前
2026年工作后学习数据分析的价值与路径
学习·数据挖掘·数据分析
qeen878 小时前
【数据结构】树的基本概念及存储
c语言·数据结构·c++·学习·
编程自留地13 小时前
项目sql语句
前端·数据库·sql
老唐77713 小时前
常见经典十大大机器学习算法分类与总结
人工智能·深度学习·神经网络·学习·算法·机器学习·ai
烟雨孤舟13 小时前
python 基础学习文档
学习
2301_8009769313 小时前
数据库的基本操作后续
java·数据库·sql
ECT-OS-JiuHuaShan13 小时前
渡劫代谢,好事多磨
数据库·人工智能·科技·学习·算法·生活
2301_7809438414 小时前
第三阶段:Gem5-GPU集成学习
学习