Mbatis中if test判断出错 status !=null and status != ‘‘

6 篇文章 0 订阅
6 篇文章 0 订阅

问题

我们一般在Mbatis中做update更新时、都会加上使用if test判断、防止更新空值、一般正常都是像name这种既判断NULL又判断’’
但是对于int类型的sex字段、如果加上 status != ''条件时、当status值为0时、此sql不会被拼加上、也不会被执行更新

<if test="name !=null and name !='' ">
    name = #{name},
</if>
<if test="status !=null">
    status = #{status},
</if>

解答

在这里插入图片描述

  • 看一下Mbatis源码
  1. mbatis中此路径为解析script标签时用到的类
org.apache.ibatis.scripting
  1. 对于mbatis来说、script标签的动态SQL、都是遍历条件做SQL拼接而成的
  2. 我们直接看org.apache.ibatis.scripting.xmltags.IfSqlNode这个类、此类是script标签中if标签的判断方式、其中evaluateBoolean返回true时、if标签下的SQL拼接生效
public boolean apply(DynamicContext context) {if (evaluator.evaluateBoolean(test, context.getBindings())) {
        contents.apply(context);return true;}return false;
}
  1. 再看org.apache.ibatis.scripting.xmltags.ExpressionEvaluator :evaluateBoolean 这个方法、我们看到了如果是number类型、会与0做判断比较
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;
}
  1. 由此可以发现、当动态sql参数是int类型、并且传入0时、是使用OgnlCache获取的value、而OgnlCache是对OGNL的封装
  2. 在OGNL的官网上面可以看到如下解释
任何需要布尔值的对象都可以使用。OGNL将对象解释为布尔值,如下所示:
·如果对象是布尔值,则提取并返回其值;
·如果对象是Number,则将其双精度浮点值与零进行比较;非零视为真,零视为假;
·如果对象是Character,则其布尔值为true,当且仅当其char值为非零时;
否则,它的布尔值为true,当且仅当它不是null时。
Any object can be used where a boolean is required. OGNL interprets objects as booleans like this:
· If the object is a Boolean, its value is extracted and returned;
· If the object is a Number, its double-precision floating-point value is compared with zero; non-zero is treated as true, zero as false;
· If the object is a Character, its boolean value is true if and only if its char value is non-zero;
Otherwise, its boolean value is true if and only if it is non-null.
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值