最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
mybatis写xml时数字类型字段设置为0时不能正常更新进数据库解决方法
时间:2020-09-21 编辑:袖梨 来源:一聚教程网
本篇文章小编给大家分享一下mybatis写xml时数字类型字段设置为0时不能正常更新进数据库解决方法,文章代码介绍的很详细,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。
项目内更新数据时,发现数字类型字段设置为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}
原因是什么呢
跟踪了下代码,发现在解析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(); } else 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); //这个位置会把'‘空串处理成0 return s.length() == 0 ? 0.0D : Double.parseDouble(s); } } } }
我们看上面最后一段代码,会把''转换成0.0D,那么我们的最开始的if判断就变成了age != 0,所以当我们把age设置为0时,结果就变成了false,导致sql不会进行拼接,更新数据失败。
相关文章
- SpringBoot自定义bean绑定解析 10-24
- Javaweb工程运行报错HTTP Status 404解决教程 10-20
- JAVA获取jvm和操作系统相关信息方法 10-20
- BeanFactory和FactoryBean的区别讲解 10-20
- 微信小程序的宿主环境实现教程 10-10
- dispatchEvent解决重叠元素响应事件教程 10-10