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

相关推荐
l1t2 分钟前
duckdb polyglot 插件的使用
sql·duckdb
Asher阿舍技术站1 小时前
【AI基础学习系列】四、Prompt基础知识
人工智能·学习·prompt
CappuccinoRose2 小时前
CSS 语法学习文档(十三)
前端·css·学习·postcss·模块化·预处理器
im_AMBER2 小时前
Leetcode 121 翻转二叉树 | 二叉树中的最大路径和
数据结构·学习·算法·leetcode
じ☆冷颜〃3 小时前
随机微分层论:统一代数、拓扑与分析框架下的SPDE论述
笔记·python·学习·线性代数·拓扑学
前路不黑暗@5 小时前
Java项目:Java脚手架项目的地图服务(十)
java·数据库·spring boot·笔记·学习·spring cloud·maven
-To be number.wan5 小时前
算法学习日记 | 双指针
c++·学习·算法
科技林总5 小时前
【系统分析师】9.1 信息系统安全体系
学习
爱问问题的小李6 小时前
AI生成的Threejs常用Api学习计划
人工智能·学习
沄媪6 小时前
CTF备赛学习
学习·ctf备赛·安全入门·windows安全系统