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

  • 相关阅读:
    NOIP模拟 回文序列
    NOIP模拟 最佳序列
    BZOJ 2783 树
    BZOJ 3631 松鼠的新家
    洛谷 6道简单图论
    NOI模拟 颜色
    NOIP模拟 Game
    BZOJ1415 聪聪与可可
    Codeforces Round #443 (Div. 2) C: Short Program
    20171028洛谷NOIP模拟
  • 原文地址:https://www.cnblogs.com/zzb-yp/p/11686046.html
Copyright © 2011-2022 走看看