MyBatis用if过滤不传值判空

MyBatis用if过滤不传值判空

问题描述:

  • Mybaits使用if过滤,查询条件为空的时候,数据集合中的数据将status=1的数据过滤掉了

  • 之前遇到的问题链接:2021-02-23遇到的问题.

分析:

我的查询条件param为空时,因为status为int默认为0,
等价于status=0,过了status != null的判断

{
  "pageNum": 1,
  "pageSize": 15,
  "param":{}
}

因此以status=0为条件过滤了数据,只显示status为0的数据,而且在param中使用"status":1查询还能查出status=1的数据

解决:

<if test=" status != 0 " >

将status字段原本的0改为-1,所以 int/integer要注意0的使用
或者将int改为integer

注:
参考:int的默认值为0,而Integer的默认值为null.
Java为每个原始类型提供了封装类,Integer是java为int提供的封装类。
int的默认值为0,而Integer的默认值为null,即Integer可以区分出未赋值和值为0的区别,int则无法表达出未赋值的情况。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值