昨天测试突然提示我一个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,则条件正常可用了。