Mybatis if test 条件参数为0的一个坑

39 篇文章 3 订阅
17 篇文章 1 订阅

问题描述

今天发现mybatis if test 条件参数为0的一个坑,在此记录一下

主要内容如下

原代码,我是要用用户id作为参数进行拼接查询的

  <if test="sign.userId!=null and sign.userId!=''">
         and ds.user_id=#{sign.userId}
  </if>

 看起来好像没什么问题,就是userId不为空的时候,进行拼接查询,然后我就调用接口

 查出来的数据是不对的,我看了下日志执行的sql如下

select ds.id, ds.company_name, ds.title, ds.user_id, ds.confirm_time , ds.remark, ds.sign_type, dsi.signator_status, dsi.company_name as otherCompanyName from dmyz_sign ds left join dmyz_signator dsi on ds.id = dsi.sign_id where ds.is_deleted = 0 

很明显没有把参数加进来,也就是说在if标签判断里面 0是没用通过的

通过查询资料发现

mybatis查询时。遇到这种如果传进来的的参数值为0 ,直接跳出if不执行

问题在于参数类型
’’ != userId 只能作用于string,int 、double、float等类型的参数默认值为0 ,将直接跳出if,
删掉后面的空字符串判断即可

解决方案

改为这种方式

 <if test="null !=sign.userId ">
                and ds.user_id=#{sign.userId}
</if>

再次运行,完美解决

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

小花皮猪

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

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

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

打赏作者

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

抵扣说明:

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

余额充值