
springboot 项目运行时突现神秘错误
近期,一位开发人员在springboot项目运行过程中遭遇了一个困扰其许久的错误:
creating a new sqlsession sqlsession [org.apache.ibatis.session.defaults.defaultsqlsession@2dbe837b] was not registered for synchronization because synchronization is not active
令人诧异的是,项目代码并未做任何改动,以往运行良好。困惑不解的开发人员在网上苦苦搜寻答案,却发现这个错误并不是常见的代码错误。
进一步排查,开发人员检查了项目的yml配置文件,发现相关配置如下:
server:
port: 8080
spring:
datasource:
druid:
driver-class-name: com.mysql.cj.jdbc.driver
url: jdbc:mysql://110.35.20.7:3306/cos?useunicode=true&characterencoding=utf8&autoreconnect=true&allowmultiqueries=true&zerodatetimebehavior=converttonull&usessl=false&servertimezone=asia/shanghai
username: mes_it
password: 123456
mybatis-plus:
config-location: classpath:mybatis/mybatis-config.xml
mapper-locations: classpath:mybatis/mapper/*.xml检查配置后,开发人员发现并没有明显的错误。正当他一筹莫展之际,一位经验丰富的程序员为他指点了一条明路:
解决办法:
前往 csdn 博客网址 https://blog.csdn.net/web1829...,查看一篇题为《sqlsession [org.apache.ibatis.session.defaults.defaultsqlsession@2dbe837b] was not registered for synchronization because synchronization is not active》的文章。
这篇文章详细分析了导致该错误的原因,并给出了相应的解决方案。按照文章中的指导,开发人员在项目中添加了以下代码:
@Configuration
public class MyBatisConfig {
@Bean
@Scope("prototype")
@Primary
public SqlSessionFactory sqlSessionFactory(@Qualifier("dataSource") DataSource dataSource) {
return new SqlSessionFactoryBean().getObject();
}
}添加代码后,开发人员重新启动项目,错误消失,项目恢复正常运行。
以上就是SpringBoot 项目运行时突现神秘错误:SqlSession 未注册,项目代码无改动,该如何解决?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号