bug篇——Mybatis中Mapper.xml文件的if判断问题
一、问题描述
上述表达,当传入参数validCoupon的值为“1”时,仍然不能执行if判断下的sql语句。
二、剖析原因
public class ExpressionEvaluator {
public boolean evaluateBoolean(String expression, Object parameterObject) {
Object value = OgnlCache.getValue(expression, parameterObject);
if (value instanceof Boolean) return (Boolean) value;
if (value instanceof Number) return !new BigDecimal(String.valueOf(value)).equals(BigDecimal.ZERO);
return value != null;
}
上述代码是mybatis递归if条件,拼接sql的源码,使用了OGNL表达式,而传入的‘1’会被解析成字符类型,在java中,Char和String方然是不一样的,返回false。
三、问题解决
第一种就是将Char类型转化成String类型,<if test="validCoupon == '1'.toString() ">
第二种就是直接传入时就是String类型,<if test=' validCoupon == "1" '>