mybatis写xml时数字类型千万别用 !=‘‘(不为空串)进行判断的示例详解

网友投稿 484 2023-03-11

mybatis写xml时数字类型千万别用 !=‘‘(不为空串)进行判断的示例详解

前言

最近项目内更新数据时,发现数字类型字段设置为0时不能正常的更新进数据库,我们打印了下mybatis的sql日志发现字段为0的sql没有被拼接。

样例

下面的是错误示例 ❌

update people

set

age=#{age},

,

modified = sysdate()

where user_id = #{userId}

age是个int类型的数据,我们在写age判断的时候就增加上了判断age!='',这个是存在问题的。

正确的示例 ✅

update people

set

age=#{age},

,

modified = sysdate()

where user_id = #{userId}

</updatOFzcPe>

原因是什么呢

跟踪了下代码,发现在解析xml时数字类型会走下面的判断

public abstract class OgnlOps implements NumericTypes {

//省略其他无用代码

public static double doubleValue(Object value) throws NumberFormatException {

if (value == null) {

return 0.0D;

} else {

Class c = value.getClass();

if (c.getSuperclass() == Number.class) {

return ((Number)value).doubleValue();

} elseOFzcP if (c == Boolean.class) {

return (Boolean)value ? 1.0D : 0.0D;

} else if (c == Character.class) {

return (double)(Character)value;

} else {

String s = stringValue(value, true);

//这个位置会把'‘空http://串处理成0

return s.length() == 0 ? 0.0D : Double.parseDouble(s);

}

}

}

}

我们看上面最后一段代码,会把''转换成0.0D,那么我们的最开始的if判断就变成了age != 0,所以当我们把age设置为0时,结果就变成了false,导致sql不会进行拼接,更新数据失败。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Spring boot webService使用方法解析
下一篇:浅谈Maven安装及环境配置出错的解决办法
相关文章

 发表评论

暂时没有评论,来抢沙发吧~