Mybatis if标签中Integer类型传入的值为0时判空不通过问题

💗一. 问题描述 💗

今天在撸代码写了一个sql,在if标签判空时,Integer类型的一个字段传入的值为0时,怎么都不通过,但明明是有值的,于是各种找问题,最后发现是Integer类型传入的值为0时判空写!=''时,出现了问题,案例如下:

<update id="update">
   	update user
   	set
      
   		<if test="num!=null and num!= ''">
   			num = #{num}
   		</if>
   	
   	where id = 1
</update>

当传入的user属性num的值为0时,mybatis预编译上面的sql为:update user where id = 1 ;然后.....就报错了.......;

那么,这是什么原因呢?

💁二. 解析💁

mybatis在预编译sql时,是使用ognl表达式解析的,在对于Integer类型判断不等于''时,ognl是判断''的长度,而''的长度就是0;

源码:(s.length() == 0) ? 0.0 : Double.parseDouble( s )

所以if标签中的num!= ''就相当于num!= 0,所以当num的值为0时,if条件判断就会不通过。

🏃三.总结🏃

1:在if标签中判断number类型时,不需要判断'',只需判断null就行;

2:可以换成基本数据类型,因为基本数据类型有默认值


   

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值