Springboot3整合Mybatis-plus3.5.3报错
最佳答案 问答题库658位专家为你答疑解惑
✅作者简介:大家好,我是Leo,热爱Java后端开发者,一个想要与大家共同进步的男人😉😉
🍎个人主页:Leo的博客
💞当前专栏: 报错以及Bug
✨特色专栏: MySQL学习
🥭本文内容:记录一次Docker与Redis冲突
🖥️个人小站 :个人博客,欢迎大家访问
📚个人知识库: 知识库,欢迎大家访问
- 学习推荐 :
- 讲师:孙帅老师
- 课程:孙哥主页
1.前言背景
大家好,我是Leo哥🫣🫣🫣,最近在学习SpringBoot3相关的的代码,开发过程中遇到了一些小坑,不过很快都解决了。然后就用 SpringBoot3 版本写了几个小 demo,比如 Web 开发、连接 数据库、使用 JdbcTemplate 操作数据库,编码和测试都非常顺利,虽然是从 SpringBoot 2.x 版本升级到SpringBoot3,但是没有感觉到太多差别。
不过,在使用 SpringBoot3 整合 MyBatisplus 时出现了一些问题,花了不少时间处理。
2.开发环境
因为这边想学习一下关于SprigBoot3的一些特性,我这里是从原来的SpringBoot2.3.6升级到了SpringBoot3.0。
使用的版本如下所示。
- Spring Boot 版本配置
<parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>3.0.3</version>
</parent>
- MyBatis 版本配置
<!--mybatis-plus-->
<dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.5.3</version>
</dependency>
3.问题出现
当一切都配置完成之后,启动项目之后,直接报错,这里直接把报错相关的贴出来。
当然,异常信息挺多,比如无法创建 Bean 的异常等等,不过上面的几个异常并不是问题主因。这里我直接定位到最后的异常上,异常信息是:
Property 'sqlSessionFactory' or 'sqlSessionTemplate' are required
于是我们跟入代码发生异常的地方。
问题原因也很明显,sqlSessionTemplate 对象是空的,所以这边就直接报错了。
4.问题排查
当然,由于把 SpringBoot 版本升级到 3 了,所以会觉得有很大的可能是版本升级导致了问题。
不过还是想自己查查问题,就依次检查了代码、数据库配置、MyBatisPlus 配置,都没有发现哪里写错了,接着就没头绪了。之后就通过源码Debug了一下,顺着启动流程走了一下,在SqlSessionFactoryBean这里发现了问题,NestedIOException这个类爆红了,正常情况下肯定是不会报错的。
说明肯定是因为我们dataSource数据源的问题,于是我又重新检查了一下代码。最终在启动类发现了问题。
下面我贴出截图
在SpringBoot应用程序启动类上加上(exclude = {DataSourceAutoConfiguration.class})会排除数据源的自动配置,这意味着我们需要手动配置数据源和事务管理器等依赖项。
如果使用MyBatis等持久层框架进行数据库操作,通常需要进行以下两个步骤:
- 配置数据源:在配置文件中设置数据库连接信息,例如连接URL、用户名、密码等。
- 配置SqlSessionFactory和SqlSessionTemplate:这两个对象是MyBatis框架中用于操作数据库的核心组件。SqlSessionFactory用于创建SqlSession实例,SqlSessionTemplate是对SqlSession的一种封装,提供了更加简单易用的API接口。
如果SqlSessionTemplate对象为空,可能有以下几种原因:
- 没有正确配置数据源:如果我们没有正确配置数据源,SqlSessionFactory和SqlSessionTemplate就无法正常创建。需要确保配置文件中的数据库连接信息正确,并且已经将数据源和事务管理器纳入到Spring容器中。
- 没有正确配置SqlSessionFactory和SqlSessionTemplate:即使我们已经正确配置了数据源和事务管理器,但是如果没有正确配置SqlSessionFactory和SqlSessionTemplate,也会导致SqlSessionTemplate对象为空。需要检查一下SqlSessionFactory是否已经成功创建,并且使用了正确的MyBatis配置文件。
- 没有将SqlSessionTemplate纳入到Spring容器中:在Spring Boot应用程序中,我们需要将SqlSessionTemplate对象纳入到Spring容器中,这样才能在其他组件中自动注入SqlSessionTemplate对象。需要确保已经在配置文件中正确配置了MyBatis相关的Bean,并且使用了正确的注解或XML配置方式来将SqlSessionTemplate纳入到Spring容器中。
需要注意的是,这里所说的原因并不全面,具体问题需要根据实际情况来进行排查分析。
我这里把这个注释掉之后,项目就正常启动了,大家可以参考一下。
5.总结
以上便是本文的全部内容,本人才疏学浅,文章有什么错误的地方,欢迎大佬们批评指正!我是Leo,一个在互联网行业的小白,立志成为更好的自己。
如果你想了解更多关于Leo,可以关注公众号-程序员Leo,后面文章会首先同步至公众号。
99%的人还看了
相似问题
- ODBC配置数据源及相关问题(“找不到工程和库”“实时错误91对象变量或with块变量未设置”等)
- .NET6使用MiniExcel根据数据源横向导出头部标题及数据
- 【Spring】使用三方包进行数据源对象(数据库)管理
- mybatis-plus3.5.3.1 支持不同数据源sql适配
- Python与ArcGIS系列(六)查找和修复数据源
- SpringBoot实现mysql与clickhouse多数据源
- SpringBoot使用MyBatis多数据源
- springboot中多数据源配置和使用
- 若依分离版——配置多数据源(mysql和oracle),实现一个方法操作多个数据源
- GNSS常用数据源汇总
猜你感兴趣
版权申明
本文"Springboot3整合Mybatis-plus3.5.3报错":http://eshow365.cn/6-32661-0.html 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!