postman转参的是“” mybatis将“”当0处理问题

发布时间:2023年12月22日

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>

文章来源:https://blog.csdn.net/liuming690452074/article/details/134650329
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。