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

相关推荐
做cv的小昊1 天前
计算机图形学:【Games101】学习笔记05——着色(插值、高级纹理映射)与几何(基本表示方法)
笔记·opencv·学习·计算机视觉·图形渲染·几何学
车载测试工程师1 天前
CAPL学习-CAN相关函数-统计API函数
网络·网络协议·学习·capl·canoe
hopsky1 天前
ShardingSphere功能简介
数据库·sql
好奇龙猫1 天前
【AI学习-comfyUI学习-第二十四节-open(contorlnet多重处理)+图生图openpose-各个部分学习】
人工智能·学习
武昌库里写JAVA1 天前
iview-CRUD模板
vue.js·spring boot·sql·layui·课程设计
wanzhong23331 天前
CUDA学习5-矩阵乘法(共享内存版)
深度学习·学习·算法·cuda·高性能计算
PNP Robotics1 天前
PNP机器人受邀参加英业达具身智能活动
大数据·人工智能·python·学习·机器人
iconball1 天前
个人用云计算学习笔记 --24 虚拟化、KVM 基础使用与热迁移实验、VMware ESXi笔记
运维·笔记·学习·云计算
男孩李1 天前
linux下如何执行postgres数据库的sql文件
数据库·sql·postgresql
zwjapple1 天前
MySQL SQL 面试核心考点与注意事项总结
数据库·sql·mysql