快捷搜索: 王者荣耀 脱发

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

<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,则条件正常可用了。

经验分享 程序员 微信小程序 职场和发展