【大坑】MyBatisPlus使用updateById莫名将数据四舍五入了

问题描述

我目前在为本地的一所高中开发一个成绩分析的网站,后端使用的是SpringBoot+MyBatisPlus,业务逻辑是用户在前端上传EXCEL文件,后端从文件中读取成绩存到数据库用于分析。但是奇怪的是:在后端,进入数据库之前的成绩数据是64.5,到数据库之后就变成了65.0

代码如下:

java 复制代码
System.out.println("插入到数据库的subjectScore: " + subjectScore);
if (subjectScore1 != null) {
	subjectScoreDao.updateById(subjectScore);
}
else subjectScoreDao.insert(subjectScore);

从现象上分析,肯定不是数据库字段的精度问题,因为数据库中的数据已经出现小数了。

分析

代码中的subjectScore1 是判断数据库中是否有相同id的数据,如果subjectScore1 不为空,则有。因为我的数据库在之前就已经导入过数据了,所以一直执行的是那个updateById方法。

抓耳挠腮想了半天,将数据库中的数据删除了之后在重新导入,发现数据又正常了,是64.5。

这就说明insert方法没问题,一更新之后就又变成了65.0。真相大白!

updateById就是罪魁祸首!

解决

将代码换成下面的

java 复制代码
System.out.println("插入到数据库的subjectScore: " + subjectScore);
if (subjectScore1 != null) {
	LambdaQueryWrapper<SubjectScore> slqw = new LambdaQueryWrapper<>();
	slqw.eq(SubjectScore::getScId,subjectScore1.getScId());
	subjectScoreDao.update(subjectScore,slqw);
}
else subjectScoreDao.insert(subjectScore);

也就是换成update方法。解决

我估计改成将原数据删除了之后在insert插入也行。

以后反正我是不会在使用updateById这个玩意了。(虽然可能是我自己的问题)。


笔者见识粗浅,对MyBatisPlus和SpringBoot的原理也不甚了解。如有大佬愿意解释更深层次的原因的话,在下洗耳恭听。

相关推荐
忍者必须死1 分钟前
JDK1.7的HashMap的环形链表
java·数据结构·算法·链表
鹿角片ljp4 分钟前
短信登录:基于 Session 实现(黑马点评实战)
java·服务器·spring boot·mybatis
北风toto5 分钟前
JDK8(JAVA)供应商说明
java·开发语言
清水白石0086 分钟前
观察者模式全解析:用 Python 构建优雅的事件系统,让组件彻底解耦
java·python·观察者模式
xiaoccii11 分钟前
C++(入门版)
java·c++·算法
上下求索,莫负韶华18 分钟前
java-(double,BigDecimal),sql-(decimal,nuermic)
java·开发语言·sql
ID_1800790547323 分钟前
淘宝商品详情 API 接口 item_get: 高效获取商品数据的技术方案
java·前端·数据库
间彧25 分钟前
布隆过滤器详解与Redis+Spring Boot实战指南
java
躲在云朵里`39 分钟前
Jeecgboot框架-权限控制
java·开发语言
Ai runner40 分钟前
Show call stack in perfetto from json input
java·前端·json