1. 背景
在写动态sql时,经常会用 <if test="">
判断对象的字段是否为空或是否为空字符串
有一个场景:一个对象的字段,在动态sql中会使用两次
<where>
<if test="dto.status != null and dto.status != ''">
<!-- 片段1 -->
</if>
<if test="dto.status != null and dto.status != 1">
<!-- 片段2 -->
</if>
</where>
像上面一样,理想的结果就是当 status 同时符合条件时,可以拼接上片段1和片段2,但是观察实际sql并没有
2. 问题原因
调试了很久,最后突然发现 status 是 Long 类型!!!
也就是说,dto.status != ''
永远都是false
[ 捂脸 ]
最后把 dto.status != ''
删除即可
写这篇文章,用于提醒自己,以后写动态sql时,要关注数据类型的字段!!!
而且如果是数据类型,就直接把 != ''
给删除掉,以防下次直接拷贝出错