Integer参数为0时,mybatis不生效

mybatis接收Integer参数时,若参数值为0,为被解析为空字符串' '。

平时写法

<if test="status != null and status != ''">
		and ppi.status =#{status}
</if>

初步-解决方案:

  1. 只判断Integer参数不为null,不用判断参数不为空字符串;

<if test="status != null">
    and ppi.status =#{status}
</if>

2.可以判断参数不等于0

<if test="status != null and status != '' or status == 0">
  and ppi.status =#{status}
</if>

上述两种方法都会存在一个问题,因为int类型默认为0;当前端查询条件为空的时候,访问到后台的接口时,查询到的数据还是用0筛选出来的数据,

问题出现在我的status设计中:

我的status这样定义的:0-未启动,1-进行中,2-延期中,3-已完成

解决方法:

1、改变status定义,变为1-未启动,2-进行中,3-延期中,4-已完成(改动太大,就没用这种)

改动之后sql写法和平时写法一样

2、将int类型的status的默认值改成999。

<if test="status != null and status != 999">
    and ppi.status =#{status}
</if>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

要成为大V的小v

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值