zoukankan      html  css  js  c++  java
  • 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" '>

  • 相关阅读:
    汇编讲解(上)--逆向开发
    两数之和 II
    解析器模式--设计模式
    访问者模式--设计模式
    命令模式--设计模式
    ccf-201512-2 消除类游戏
    ccf-201503-2 数字排序
    移动端兼容和适配问题
    ccf-201409-2 画图
    ccf-201409-3 字符串匹配
  • 原文地址:https://www.cnblogs.com/zzb-yp/p/11686046.html
Copyright © 2011-2022 走看看