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

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>

  • 10
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值