大坑"/>
Mybatis if test判断之大坑
1、问题:
当传入参数validCoupon的值为“1”时,仍然不能执行if判断下的sql语句。
2、原因:
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。
3、问题解决:
第一种就是将Char类型转化成String类型,<if test="validCoupon == '1'.toString() ">
第二种就是直接传入时就是String类型,<if test=' validCoupon == "1" '>
更多推荐
Mybatis if test判断之大坑
发布评论