Mybatis if 判断等于一个字符串
使用Mybatis时经常会用到 if 判断等于一个字符串,明明写法没问题,参数也没问题但就是进不去里面的代码。这个是很多人会踩的坑
<if test=" name!=null && name =='1' ">
and status = 0
<if/>
- 1
- 2
- 3
解决方案
- 方案一
把这个转换成 单引号。这样就解决了。
<if test=‘ name!=null && name =="1" '>
and status = 0
<if/>
- 1
- 2
- 3
- 方案二
将等于的值转成字符串
<if test=" name!=null && name =='1'.toString() ">
and status = 0
<if/>
- 1
- 2
- 3
提示:int 和 一个String 会导致不等
但是在做开发的时候也会遇到这样一个问题:当传入的type的值为t的时候,if判断内的sql也不会执行。
<if test="type=='t'">
and status = 0
</if>
- 1
- 2
- 3
解决方案
//这里外面用的叔单引号,里面用的是双引号
<if test='type=="y"'>
and status = 0
</if>
- 1
- 2
- 3
- 4
提示:mybatis是使用的OGNL表达式来进行解析的,在OGNL的表达式中,'t’会被解析成字符,因为java是强类型的,char 和 一个String 会导致不等。所以if标签中的sql不会被解析。