使用Mybatis遇到的坑之Integer类型参数的解读
使用Mybatis遇到的坑之Integer类型参数
有时候我们使用实体类传递参数时,有些属性会被设置为Integer类型,比如status、sort等,在这里,使用Integer类型参数作为条件时
要注意一点:例如
<if test="bean.activitySort != null and bean.activitySort !="""> AND activity_sort = #{bean.activitySort,jdbcType=VARCHAR} </if>
这里对于bean.activitySort的判断正常情况下如果activitySort是String类型,先判空,再判断是否是空字符串,这样是正常的,但是如果activitySort是Integer类型参数,那么使用时就需要注意,此处不能对activitySort进行空字符串的判断,因为什么呢?
因为mybatis在解析Integer类型数据时,如果数据值为0,会将0解析为空字符串,这样你传入的参数就成为无效的了,所以正常使用Integer类型参数应该是下面这样:
<if test="bean.activitySort != null"> AND activity_sort = #{bean.activitySort,jdbcType=VARCHAR} </if>
Mybatis的xml,Integer类型参数bug问题
当有Integer数据类型的参数值为0时,如pid=0,xml中pid==“” 判断为ture,即不走条件语句
<if test="pid != null and pid != '' "> AND a.pid = #{pid} </if>
正确写法一:还要加上一句 or pid==0
<if test="pid != null and pid != '' or pid ==0"> AND a.pid = #{pid} </if>
正确方法二:去掉and pid != ''的条件
<if test="pid != null "> AND a.pid = #{pid} </if>
原因分析
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Springboot+redis+Interceptor+自定义annotation实现接口自动幂等
本篇文章给大家介绍了使用springboot和拦截器、redis来优雅的实现接口幂等,对于幂等在实际的开发过程中是十分重要的,因为一个接口可能会被无数的客户端调用,如何保证其不影响后台的业务处理,如何保证其只影响数据一次是非常重要的,感兴趣的朋友跟随小编一起看看吧2019-07-07
最新评论