mybatis test把整数0等同于空字符串

今天在使用mybatis时遇到一个问题,java代码中传递的整数0在mybatis中被识别成null

 

   <where>
   	<if test="status != null and status !=''">
   		and status=#{status,jdbcType=INTEGER}
   	</if>
   </where>

 

 

如果java代码需要往mybatis传递整数0,那么需要使用增强版的判断,具体如下所示:

 

   <where>
   	<if test="status != null and status !='' or status=='0'.toString()">
   		and status=#{status,jdbcType=INTEGER}
   	</if>
   </where>

或者可以采用

   <where>
   	<if test="@org.apache.commons.lang3.StringUtils@isNotEmpty(status)">
   		and status=#{status,jdbcType=INTEGER}
   	</if>
   </where>

 

第二种方式是采用了自定义的判断逻辑,第一种方式则是采用ognl的判断逻辑!!!

 

具体原因可以参考:https://blog.csdn.net/john1337/article/details/98225453

 

 

 

 

 

 

已标记关键词 清除标记
©️2020 CSDN 皮肤主题: 编程工作室 设计师:CSDN官方博客 返回首页