记录mybatis排查bug过程中遇到的坑

在使用公司内部数据库连接注解时,项目在本地写单元测试mybatis mapper出现了以下的bug.于是就开始了我长达一天的排查之旅,期间遇到了各位可能会遇到的坑,这里贴出来帮大家避雷。

sh 复制代码
org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.exceptions.PersistenceException: 
### Error querying database.  Cause: io.shardingjdbc.core.exception.ShardingJdbcException: io.shardingjdbc.core.exception.ShardingJdbcException: java.sql.SQLException: Error
### The error may exist in file [/Users/******/IdeaProjects/umepsr-partnersub/umepsr-partnersub-aq/target/classes/mappers/Mapper.xml]
### The error may involve defaultParameterMap
### The error occurred while setting parameters
### SQL: select           PXID,         CERTID,         CERTTYPE,                 SOURCE,         STARTDATE,         ENDDATE,         STATUS,         SUBSCRIBETYPE,         CREATETIME,         UPDATETIME       from          where SUBSCRIBETYPE = ? and CERTID =? and CERTTYPE = ?
### Cause: io.shardingjdbc.core.exception.ShardingJdbcException: io.shardingjdbc.core.exception.ShardingJdbcException: java.sql.SQLException: Error

第一坑:虚晃一枪

按照报错的指引,我找到了打包后Target文件夹中的Mapper文件。

The error may exist in file [/Users/******/IdeaProjects/umepsr-partnersub/umepsr-partnersub-aq/target/classes/mappers/Mapper.xml]

如图所见,我当时看到这个我真的以为自己遇见了鬼。

是的,同一个mapper文件在开发时不爆红,但是编译入target中他爆红了。搞得我一度以为是我写的mapper文件语法有问题。

经过我与通过其他生产环境上正常项目比对后,我十分确认这个mapper文件爆红的地方他没问题,况且正常目录中他也没报错啊,侧面证实了我的观点。

排除所有错误答案,剩下的再离谱也是正确答案,那就是最新版的IDEA仍存在这样一个bug。在target目录中获取上下文存在bug,导致refid中的内容不能绑定识别到。

而且,在经过invalidate cache后,这个爆红仍然没有解决。

于是,我索性不管他了。

第二坑:雪上加霜

这个坑,纯纯我自己搞出来的。

在不甘心,被bug打败的调试挣扎中,我尝试搜索这个bug是什么原因。

查到的答案是很有可能,是数据库没连接上。原因在于:mybatis-spring-1.3.2中取消了自动注入SqlSessionFactory 和 SqlSessionTemplate

需要手动加入一下依赖,就会注入SqlSessionFactory 和 SqlSessionTemplate

xml 复制代码
<dependency>
	<groupId>org.mybatis.spring.boot</groupId>
	<artifactId>mybatis-spring-boot-starter</artifactId>
	<version>1.3.2</version>
</dependency>

结果一加一个不吭声,报错确实变了,不报原来的错,但是这次的报错更离谱。

下面的报错信息,无限循环。报错信息过长,不方便截图。

根据这位老哥的经验Caused by: java.lang.StackOverflowError-CSDN博客 通过排查,删除了项目中 log4j-over-slf4j 依赖解决了问题。

如下图:

xml 复制代码
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>1.3.2</version>
    <exclusions>
        <exclusion>
            <artifactId>log4j-over-slf4j</artifactId>
            <groupId>org.slf4j</groupId>
        </exclusion>
    </exclusions>
</dependency>

虽然解决了这个StackOverflowError,但是原有的报错仍然没有解决,只能继续在排查bug中遨游。

最终解决方案

这个时候我关注到了这个报错信息。

js 复制代码
### The error occurred while setting parameters
### SQL: select PXID,CERTID,CERTTYPE,SOURCE,STARTDATE,ENDDATE,STATUS,SUBSCRIBETYPE,CREATETIME, UPDATETIME  
from  table
where SUBSCRIBETYPE = ? and CERTID =? and CERTTYPE = ?

在一开始我是完全忽略这个问题的,毕竟我的列名一开始可是对着数据库一个一个敲的,不可能写错啊。

打脸的来了,SOURCE字段在建表语句中,没有写入。事实上,我是参考其他数据库写下这个建表语句。

一天排查bug搞得头昏脑涨,心力交瘁的,最后得到一个教训:

不要相信自己的手敲,一定要copy才最保险。

相关推荐
一 乐11 分钟前
交通感知与车路协同系统|基于springboot + vue交通感知与车路协同系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·交通感知与车路协同系统
Java面试题总结22 分钟前
FVG3 构建系统 MinGW 配置问题排查文档
java
乐之者v28 分钟前
游标分批查询,提高查询性能
java
城管不管36 分钟前
嵌入模型Embedding Model
java·开发语言·python·embedding·嵌入模型
斯维赤38 分钟前
每天学习一个小算法:选择排序
java·学习·算法
book123_0_9944 分钟前
Spring Boot 条件注解:@ConditionalOnProperty 完全解析
java·spring boot·后端
NCIN EXPE1 小时前
使用Springboot + netty 打造聊天服务(一)
java·spring boot·后端
爱学习的小囧1 小时前
ESXi性能历史怎么监控?2种方法,图形化+命令行全覆盖
java·linux·运维·服务器·网络·esxi·esxi8.0
逻辑驱动的ken1 小时前
Java高频面试考点场景题11
java·深度学习·面试·职场和发展·高效学习
学习3人组1 小时前
面向对象编程:反射(Reflection)原理与应用详解
java