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

本是古典 何须时尚 2022-06-03 01:30 410阅读 0赞

问题

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

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

经过和同事一番研查,发现integer类型的level为0时,居然被当作了‘’(空串)。后来网上查了查,原来这是mybatis规定的。

解决办法

方法一:去掉<if test="level != null and level != ''">中的and level != ” 即:

  1. <if test="level != null">

方法二:在 <if test="level != null and level != ''">中加入or level==0,即:

  1. <if test="level != null and level != '' or level==0">

发表评论

表情:
评论列表 (有 0 条评论,410人围观)

还没有评论,来说两句吧...

相关阅读