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

相关推荐
Ws_7 小时前
C#学习 Day2
开发语言·学习·c#
神谕的祝福7 小时前
comfyui从0到1开始学习-第三讲生图与降噪实验
学习
星夜夏空997 小时前
STM32单片机学习(32) —— ADC
stm32·单片机·学习
愚者Pro10 小时前
Flutter Widget组件学习(专为 Uniapp 转 Flutter 定制)
vue.js·学习·flutter·uni-app
BlackHeart120312 小时前
【SQL】Oracle中序列(Sequence)作为默认值引发的ORA-00979
数据库·sql·oracle
yzx99101312 小时前
从焦虑到掌控:关于学习AI工具的深度思考
人工智能·学习
Bechamz12 小时前
大数据开发学习Day42
大数据·学习
zhangrelay12 小时前
ROS 2 Lyrical Luth启程-Ubuntu26.04-
linux·笔记·学习·ubuntu
锦鲤521413 小时前
机器学习学习笔记
笔记·学习·机器学习
minglie113 小时前
utf8转utf16
学习