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

news/2025/2/7 1:15:33/

问题描述

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

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就是罪魁祸首!

解决

将代码换成下面的

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


http://www.ppmy.cn/news/1325990.html

相关文章

beego的模块篇 - I18n国际化

1. i18n 安装导入 安装该模块&#xff1a; go get github.com/beego/i18n 导入引用包&#xff1a; import ("github.com/beego/i18n" ) conf 目录下就有 locale_en-US.ini 和 locale_zh-CN.ini 两个本地化文件。 本地化文件的文件名和后缀是随意的&#xff0c;不…

nginx前后端不分离项目代理配置

文章目录 了解举例1&#xff1a;一个项目content-path路径配置为空&#xff0c;使用nginx代理。举例2&#xff1a;配置上项目的content-path&#xff0c;再使用ngxin代理 总结 现在很多时候都是前后端分离的项目&#xff0c;所以配置代理的时候&#xff0c;前端和后端的代理分开…

路由器初始化配置、功能配置

实验环境 拓扑图 Ip规划表&#xff08;各组使用自己的IP规划表&#xff09; 部门 主机数量 网络地址 子网掩码 网关 可用ip Vlan 市场部 38 192.168.131.0 255.255.255.0 192.168.131.1 2-254 11 研发部 53 192.168.132.0 255.255.255.0 192.168.132.1 2-2…

selenium代理ip可用性测试

测试代理ip是否工作正常&#xff0c;将正常的代理ip提取出来 from selenium import webdriver from fake_useragent import UserAgent def check_proxy(proxy):print("开始测试&#xff1a;"proxy)chrome_options webdriver.ChromeOptions()chrome_options.add_arg…

关于前端面试中forEach方法的灵魂7问?

目录 前言 一、forEach方法支持处理异步函数吗&#xff1f; 二、forEach方法在循环过程中能中断吗&#xff1f; 三、forEach 在删除自己的元素后能重置索引吗&#xff1f; 四、forEach 的性能相比for循环哪个好&#xff1f; 五、使用 forEach 会不会改变原来的数组&#…

iOS原生应用屏幕适配完整流程

1. 已iPhone 11 布局为设计布局,其他机型已这个来适配 2.变量与控件对应关系 txtViewer: txtAccount txtpwd seg btnOk 3.适配方法实现: //iOS屏幕适配 -(vo

HarmonyOS鸿蒙学习基础篇 - 什么是HarmonyOS

概述 HarmonyOS是华为开发的一款面向未来的全场景分布式智慧操作系统&#xff0c;将逐步覆盖18N全场景终端设备&#xff1b; 对消费者而言 HarmonyOS用一个‘统一的软件系统’ 从根本上解决消费者面对大量智能终端体验割裂的问题&#xff0c;为消费者带来同意便利安全的智慧化全…

【docker】之基础篇一

目录 一、docker的简单介绍二、centos7安装docker设置ustc的镜像镜像相关的命令&#xff1a;容器相关的命令创建镜像的三种方式存出和载入镜像创建与启动容器目录挂载导入和导出容器 三、redhat安装docker四、搭建本地私有仓库五、软件部署1.mysql部署2.nginx部署3.tomcat部署 …