有个小伙把 MyBatis 替换成 MyBatis-Plus,上线后就被开了!!

MyBatis-Plus 替换 MyBatis

首先,我们准备了一张名为 tbl_order 的表,并初始化了其中的两条数据。

DROP TABLE IF EXISTS `tbl_order`;
CREATE TABLE `tbl_order`  (`id` bigint(0) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '自增主键',`order_no` varchar(50) NOT NULL COMMENT '订单号',`pay_time` datetime(3) DEFAULT NULL COMMENT '付款时间',`created_at` datetime(3) NOT NULL DEFAULT CURRENT_TIMESTAMP(3) COMMENT '创建时间',`updated_at` datetime(3) NOT NULL DEFAULT CURRENT_TIMESTAMP(3) ON UPDATE CURRENT_TIMESTAMP(3) COMMENT '最终修改时间',PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB COMMENT = '订单';INSERT INTO `tbl_order` VALUES (1, '123456', '2024-02-21 18:38:32.000', '2024-02-21 18:37:34.000', '2024-02-21 18:40:01.720');
INSERT INTO `tbl_order` VALUES (2, '654321', '2024-02-21 19:33:32.000','2024-02-21 19:32:12.020', '2024-02-21 19:34:03.727');

我们只是简单地将 MyBatis-Plus 替换了 MyBatis,而其他组件的版本保持不变。

我们使用的 MyBatis-Plus 版本是:3.1.1,

而 mysql-connector-java 的版本保持不变,仍然是 5.1.26。

示例代码:play_it_safe

然后,运行 com.qsl.OrderTest#orderListAllTest,却遇到了报错,异常信息如下所示:

请注意 Caused by 部分。

图片

不支持的转换类型:java.time.LocalDateTime

是谁不支持呢?是 mysql-connector-java 不支持!

那么,哪个版本的 mysql-connector-java 支持呢?

答案是:5.1.37

图片

升级 mysql-connector-java

我们将 mysql-connector-java 升级到 5.1.37,然后再次执行 com.qsl.OrderTest#orderListAllTest

图片

这次不再报异常,并且查询结果也是正确的。

看起来,MyBatis-Plus 替换 MyBatis 的任务完成了。

这一切都如此顺利,让人有些怀疑。

图片

让我们再回头看看之前提到的异常:

Conversion not supported for type java.time.LocalDateTime

在替换 MyBatis 之前并没有这个异常,但在替换之后就出现了这个异常,这难道不是 MyBatis-Plus 的问题吗?

那么如何找到这个异常的根本原因呢?

其实很简单,直接从异常堆栈入手。

图片

点击后,你会发现代码非常简单。

图片

这么简单的代码怎么会有问题呢?

大家请注意图中左上角的 MyBatis 版本,是 3.5.1,而不是最初的 3.5.0。

可能有人会问:「既然替换成了 MyBatis-Plus,为什么还有 Mybatis 的存在?」

这个问题问得确实好,我只想给你个大嘴巴。

图片

现在让我们看一下 MyBatis-Plus 的官方说明。

图片

既然基于 Mybatis 3.5.0 没有抛出异常,而基于 3.5.1 却抛出了异常。

“LocalDateTimeTypeHandler” 在 3.5.1 中肯定进行了调整

那我们来看看调整了什么?

图片

看出什么了吗?

MyBatis 3.5.0 会处理 LocalDateTime 类型的转换(将 java.sql.Timestamp 转换成 java.time.LocalDateTime)。

然而,注意了啊,最关键的地方来了!

从 MyBatis 3.5.1 开始,不再处理 LocalDateTime(还包括:LocalDate、LocalTime)类型的转换,而是交由 JDBC 组件,也就是 mysql-connector-java 来实现。

而巧的是:

mysql-connector-java 5.1.26 不支持类型 LocalDateTime。

图片

那么它支持哪些类型呢?

我们同样从异常堆栈入手。

图片

点击后,可以看到下图。

图片

往上滑动鼠标,就可以看到支持的类型。

确实没有 LocalDateTime、LocalDate 和 LocalTime。

mysql-connector-java 5.1.37 开始支持 LocalDateTime、LocalDate 和 LocalTime,前面已经介绍过了,不再赘述。

总结异常根本原因:

MyBatis 3.5.1 开始不再处理 LocalDateTime、LocalDate 和 LocalTime 的转换,而 mysql-connector-java 5.1.37 之前都不支持这些类型。

搞清楚了这个异常的来龙去脉,顺理成章的感觉是不是又回来了?

暴风雨来临

版本上线不到两天,该来的终究还是来了。

我们往表 tbl_order 中插入了一条记录:

INSERT INTO tbl_order 
VALUES (3, 'asdfgh', NULL, '2024-02-21 20:01:31.111', '2024-02-21 20:02:56.764');

然后再次执行 com.qsl.OrderTest#orderListAllTest

图片

此时我就想问这位年轻人:爽不爽?

图片

遇到了异常,那就找出原因。

同样从异常堆栈入手。

图片

看出什么了吗?

如果 getTimestamp(columnIndex) 得到的是 NULL,那不就是 NullPointerException?这也太不严谨了吧?

修复问题是当务之急,先看哪个版本进行了修复?

图片

将 mysql-connector-java 升级到 5.1.42。

图片

问题得以修复。

经过这一次事件,这位年轻人似乎成长了许多,但眼中的光却黯淡了不少。

Mybatis-Plus 的问题

无意中我看到了这个 issue-1114,是不是和我们之前分析的 “Conversion not supported for type java.time.LocalDateTime” 是同一个问题?

只是我们使用的数据库连接池是默认的 HikariCP 而非 Druid。

结合 druid/issues/3302,如果使用 Druid 作为数据库连接池,出现的异常可能与我们之前分析的确实不同。

因此,大家需要根据自己的实际情况进行分析,但对异常的分析方法是通用的。

总结

关于组件的升级或旧代码的调整,都可能引发连锁反应,影响重大。

我的观点是:

能不动就不要动,改好没功劳,改坏要背锅,吃力不讨好,又不是必须要改。

如果不得不改,那就需要全面的测试。

最后说一句(求关注!别白嫖!)

如果这篇文章对您有所帮助,或者有所启发的话,求一键三连:点赞、转发、在看。

关注公众号:woniuxgg,在公众号中回复:笔记  就可以获得蜗牛为你精心准备的java实战语雀笔记,回复面试、开发手册、有超赞的粉丝福利!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/842215.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【加密与解密(第四版)】第十八章笔记

第十八章 反跟踪技术 18.1 由BeginDebugged引发的蝴蝶效应 IsDebuggerPresent()函数读取当前进程PEB中的BeginDebugged标志 CheckRemoteDebuggerPresent() 反调试总结:https://bbs.kanxue.com/thread-225740.htm https://www.freebuf.com/articles/others-articl…

如何在工信部教考中心官网查询PG证书

1.第一步:进入工业和信息化部教育与考试中心官网 2.第二步:点击最右边“证书查询” 3.点击“工业和信息化部教育与考试中心培训评价证书查询” 4.在该页面按照如下方式进行证书查询:输入您的证件号码和您的证书号码以及姓名,点…

蓝桥杯备赛——DP续【python】

一、小明的背包2 试题链接:https://www.lanqiao.cn/problems/1175/learning/ 输入示例 5 20 1 6 2 5 3 8 5 15 3 3 输出示例 120 问题分析 这题是完全背包,每个物品有无数个,所以对于任意dp[i][j](其表示的意思为选到第i个…

算法设计第七周(应用哈夫曼算法解决文件归并问题)

一、【实验目的】 (1)进一步理解贪心法的设计思想 (2)掌握哈夫曼算法的具体应用 (3)比较不同的文件归并策略,探讨最优算法。 二、【实验内容】 设S{f1,…,fn}是一组不同的长度的有序文件构…

基于springboot+vue的仓库管理系统

免费获取方式↓↓↓ 项目介绍029: http://localhost:8081/ eclipse mysql jdk1.8 密码admin root 用户员(id 账号 密码 年龄 角色 电话) 仓库表(id 名称 备注) 分类表(id 名称 备注) 记录表(id…

基于翔云C#语言的身份证实名认证接口开发示例

现如今,安全与便捷成为了互联网服务的两大关键词。为了进一步提升用户体验并加强网络安全管理,国内多家主流App近日宣布完成一项重要功能升级——集成身份证实名认证系接口。这一举措标志着用户在进行App注册时,将享受到更加高效、安全的身份…

深度学习论文: YOLOv10: Real-Time End-to-End Object Detection

深度学习论文: YOLOv10: Real-Time End-to-End Object Detection YOLOv10: Real-Time End-to-End Object Detection PDF: https://arxiv.org/pdf/2405.14458 PyTorch代码: https://github.com/shanglianlm0525/CvPytorch PyTorch代码: https://github.com/shanglianlm0525/PyTo…

104-1389-006马达单价1041389006可议价

104-1389-006 产品 M 马达 系列 02 2000 系列 排量 149 244.3 CM3/R [14.91 IN3/R] 安装类型 AH 标准,4 螺栓;先导直径为 82.6 [3.25] 13.59 直径为 [0.535] 直径为 106.4 [4.19] 的孔螺栓圆周 输出轴 16 直径为 32.00 [1…

用一个装饰器代替 try except

用一个装饰器代替 try except 要写很多封装的时候,大量的使用 try except 很麻烦,直接使用python装饰器解决 import functoolsdef handle_exceptions(func):functools.wraps(func)def wrapper(*args, **kwargs):try:return func(*args, **kwargs)excep…

地铁判官:啥时候B端系统界面,也出个“判官”,讲好不准打脸。

小编所在的城市——山东青岛,出了个地铁判官,我看了视频,哈哈哈,俗世的判断标准就是那么简单直接,而放到B端系统那就难说啦。 如何判断B端系统的优劣,各位看官,各抒己见吧。 判断B端系统界面的…

智慧校园建设规划方案

在信息化浪潮的推动下,智慧校园的建设已成为教育现代化的必然趋势。以创新科技赋能教育,打造智慧校园,旨在提升教学品质,优化管理流程,增强学生体验。构建智慧校园需要具有前瞻性的规划方案,它将以教育为核…

PL5358A 单芯锂离子/聚合物电池保护IC芯片

一般说明 PL5358A系列产品是锂离子/聚合物电池保护的高集成解决方案。PL5358A包含先进 的功率MOSFET,高精度电压检测电路和延迟电路。5358A被放入一个超小的SOT23-5封装,只有一个外部元件,使其成为理想的解决方案,在有限的…

vue2+elementui 表格中操作列不定个数按钮的折叠展开

vue2elementui 实现表格中操作列不定个数按钮的折叠展开&#xff0c;可以根据自己的需求自行修改样式和展示等。基本代码如下&#xff1a; <template><div class"table-action-col-box" :ref"_bf${rowId}"><div :ref"_bf${rowId}_but…

开源博客项目Blog .NET Core源码学习(28:App.Hosting项目结构分析-16)

本文学习并分析App.Hosting项目中后台管理页面的用户管理页面。   用户管理页面用于显示、检索、新建、编辑、删除用户数据&#xff0c;其附带一新建及编辑页面&#xff0c;以支撑新建和编辑用户数据&#xff0c;同时还附带重置密码页面&#xff0c;以重置用户密码。整个页面…

SUPRA:无须额外训练,将Transformer变为高效RNN,推理速度倍增

Transformers 已经确立了自己作为首要模型架构的地位&#xff0c;特别是因为它们在各种任务中的出色表现。但是Transformers 的内存密集型性质和随着词元数量的指数扩展推理成本带来了重大挑战。为了解决这些问题&#xff0c;论文“Linearizing Large Language Models”引入了一…

android-mvp模式

mvvm可以理解成使用databing的mvp模式&#xff0c;modleview 通过接口让view和Presenter层解耦 从图中就可以看出&#xff0c;最明显的差别就是view层和model层不再相互可知&#xff0c;完全的解耦&#xff0c;取而代之的presenter层充当了桥梁的作用&#xff0c;用于操作view…

set怎么实现有序

在Java集合框架中&#xff0c;Set接口的实现类主要有三种常见的变体&#xff1a;无序的HashSet、保持插入顺序的LinkedHashSet和按自然顺序或自定义比较器排序的TreeSet。要实现有序的Set&#xff0c;可以使用LinkedHashSet或TreeSet。 有序的Set实现类 LinkedHashSet&#xf…

0基础认识C语言(代码实操)

首先呢大家要知道C语言的常见格式如下 #include <stdio.h> int main() {return 0; } 可能看起来会有点懵&#xff0c;但是不着急&#xff0c;咱们一句一句讲 #include <stdio.h> 这是一个头文件&#xff0c;是标准输入输出&#xff0c;怎么理解呢&#xff0c;你…

芯片设计 | 什么是 NVMe?

文章目录 什么是 NVMe&#xff1f;什么是固态硬盘&#xff1f;为什么 NVMe 很重要&#xff1f;NVMe、SAS 和 SATA 之间的区别只有SSD运行在NVMe上PCIe和NVMe有关系&#xff0c;但它们不是同一个东西NVMe-oF连接SSD到网络NVMe 的工作原理是什么&#xff1f;NVMe SSD 外形尺寸M.2…

零售品牌做好差旅报销管理,真的能省钱

一年一度的“618”如期而至,甚至启动更早了。 各大厂商宣布取消延用了十多年的预售机制,主打“现货开卖”,充分回归“消费者价值”。 零售品牌给消费者省钱,更要给自己省钱。而这前提是充分了解“钱花在哪了”、“怎么花更合理”: ● 商业化BD、促销、营销等市场活动频繁,差…