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" '>

posted @ 2019-10-16 15:59  不浪小生  阅读(3478)  评论(0编辑  收藏  举报