【大坑】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的原理也不甚了解。如有大佬愿意解释更深层次的原因的话,在下洗耳恭听。

相关推荐
小鸡脚来咯3 分钟前
java web后端开发流程
java·开发语言·git
北友舰长5 分钟前
基于Springboot+thymeleaf快递管理系统的设计与实现【Java毕业设计·安装调试·代码讲解】
java·spring boot·mysql·校园管理·快递·快递系统
我爱烤冷面6 分钟前
kotlin项目实现Java doc的方案:使用Dokka
java·开发语言·kotlin·dokka
jian110588 分钟前
android java转kotlin,kotlin转java
android·java·kotlin
长征coder10 分钟前
SpringCloud服务优雅下线LoadBalancer 缓存配置方案
java·后端·spring
历程里程碑11 分钟前
C++ 4:内存管理
java·c语言·开发语言·数据结构·c++·笔记·算法
没有bug.的程序员14 分钟前
微服务的本质:不是拆服务,而是拆复杂度
java·jvm·spring·微服务·云原生·容器·架构
武子康20 分钟前
Java-200 RabbitMQ 架构与 Exchange 路由:fanout/direct/topic/headers
java·架构·消息队列·系统架构·rabbitmq·java-rabbitmq·mq
计算机学姐22 分钟前
基于SSM的社区外来务工人员管理系统【2026最新】
java·vue.js·java-ee·tomcat·maven·intellij-idea·mybatis
好学且牛逼的马23 分钟前
HttpServlet 深度拆解:从设计模式看透其核心原理
java·servlet·设计模式