Mybatis中sql数组为空判断

一、Mybatis xml中的sql通过if语句判定是否为空
xml 复制代码
<if test="arrays != null">
</if>

上述示例只能判断arrays数组不为null,那如果是个空数组呢

二、Mybatis xml中的sql通过if语句判定数组非空数组

xml 复制代码
<if test="arrays != null and arrays.length > 0">
</if>

如果是按照上述写法,将会报如下已异常:

sh 复制代码
nested exception is org.apache.ibatis.builder.BuilderException: Error evaluating expression 'arrays != null and arrays.length > 0'. Cause: org.apache.ibatis.ognl.NoSuchPropertyException: java.util.ArrayList.length

正确写法如下:

xml 复制代码
<if test="arrays != null and arrays.size() > 0">
</if>

开源SDK:https://github.com/mingyang66/spring-parent

相关推荐
Dxy123931021629 分钟前
Python MySQL 错误回滚实战代码
数据库·python·mysql
Go高并发架构_王工42 分钟前
Redis未来展望:Redis 7.0新特性与技术发展趋势
数据库·redis·缓存
产幻少年1 小时前
用户登录日志表和系统日志
运维·服务器·数据库
·云扬·1 小时前
InnoDB Cluster高可用测试实战:主从切换与故障恢复验证
数据库·mysql
qq_455760852 小时前
redis - 持久化
数据库·redis·缓存
&友情岁月&2 小时前
sql脚本的union的要注意点
数据库·sql
nvd112 小时前
基于 LangChain + Gemini + CloudSQL (pgvector) 的 RAG 实现指南
数据库·langchain
oMcLin2 小时前
Ubuntu 22.04 系统升级后 PostgreSQL 无法启动:如何解决数据库迁移中的兼容性问题
数据库·ubuntu·postgresql
福尔摩斯张2 小时前
STM32数码管和LCD显示技术深度解析(超详细)
数据库·stm32·单片机·嵌入式硬件·mongodb