mybatis中if标签判断字符串相等

昨天测试突然提示我一个bug,说门店来源搜索结果有问题,按需求在mapper.xml中中的条sql的条件

<choose>
            <when test=" memberSouce!=null and memberSouce!='' and memberSouce !='2' ">
                and mem.memberSouce= #{memberSouce,jdbcType=VARCHAR}
             </when> 
             <when test="  memberSouce== '2' ">
                and mem.memberSouce in ('2','3')
             </when>
    </choose>

咋一看,我的sql没啥问题,反复确认后,发现数据也没问题,于是把日志打印sql语句,结果sql执行的结果却让我轻松不起来,明明memberSouce这个字段为2,但是在打印的日志sql中却是 mem.memberSouce= 2,并不是预期的 mem.memberSouce in ('2','3')

于是意识到是memberSouce的判断条件出了问题,在网上一顿搜索后,发现了说明:
mybatis 映射文件中,if标签判断字符串相等,两种方式:因为mybatis映射文件,是使用的ognl表达式,所以在判断字符串sex变量是否是字符串Y的时候使用

<test="sex=='Y'.toString()">或者<test = 'sex== "Y"'>

修改后

<if test="memberSouce!= null and memberSouce!=''  ">  
    <if test="memberSouce !='2'.toString() ">   
         and mem.memberSouce= #{memberSouce,jdbcType=VARCHAR}
    </if>  
    <if test="memberSouce == '2'.toString() ">   
         and mem.memberSouce in ('2','3')
    </if> 
</if>
再次调用sql,则条件正常可用了。

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值