Mybatis中 Integer 值为0时,默认为空字符串的解决办法-蒲公英云
传0当成了""
解决:
mybatis当传入数据类型为Int时并且值为0时,会判断为空字符串-腾讯云开发者社区-腾讯云
https://www.cnblogs.com/shenhaha520/articles/16301304.html
传""当成了0
?
问题:入参value为空字符串,结果返回了value为0的数据
原因:mybatis把空字符串转换成了0,所以查出了对应value为0的数据(刨根问题可以去看源码)
数据库这个字段是int类型,MyBatis会把空字符串转为0 处理;
这是一个很奇怪的问题,当post请求过来时,下面两种写法,当query.alarmStatus=''时,都会进去(下面第一个代码,会转成0),当然如果是直接等于0时,自然也会进去(第一个代码).
分不清,是为空值,不查这个状态呢,还是当0查? 这其实都有问题,最好是转成string再做处理。
<if test=" query.alarmStatus != null and query.alarmStatus != '' ">
and alarm.alarm_status = #{query.alarmStatus}
</if>
<if test=" (query.alarmStatus != null and query.alarmStatus != '') or query.alarmStatus == 0 ">
? ? ? ? ? ? ? ? ? ? ? ? ? ? and alarm.alarm_status = #{query.alarmStatus}
</if>