首页 > 其他 > 详细

Mybatis中 Integer 值为0时,默认为空字符串的解决办法。

时间:2019-03-01 14:33:52      阅读:509      评论:0      收藏:0      [点我收藏+]

需求是查询级别为0的用户
User对象里的level字段的值为0,查询时居然没有查到为level为0的用户。

<select id="selectSelective" parameterType="com.agri.entity.User" resultMap="map">
select * from sys_user where del_flag = 1
<if test="level != null and level != ‘‘">
and level = #{level,jdbcType=INTEGER}
</if>
</select>

查资料得知:mybatis规定,mybatis在进行判断时,会将integer=0的参数默认为‘’(空串)。

解决办法
方法一:

去掉<if test="level != null and level != ‘‘">中的and level != ” 即:

<if test="level != null">

方法二:

在 <if test="level != null and level != ‘‘">中加入or level==0,即:

<if test="level != null and level != ‘‘ or level==0">

Mybatis中 Integer 值为0时,默认为空字符串的解决办法。

原文:https://www.cnblogs.com/ZJOE80/p/10456165.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!