解决Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlS..(22.11.20)

解决过程:

1、初始方案

在我们没有开启事务的时候,如果使用mybatis,我们会在日志中看到如下的内容:“Closing non transactional SqlSession”,这种情况说明没有开启Spring的事务管理,因此才会关闭一个非事务的SqlSession。

那么如何开启事务管理呢?最简单的方式就是添加下面两条配置:

<!-- 配置事务管理器 -->
    <bean id="transactionManager"
          class="org.springframework.jdbc.datasource.DataSourceTransactionManager"
          p:dataSource-ref="dataSource" />

    <!-- 指明使用注解的方式来管理事务 -->
    <tx:annotation-driven transaction-manager="transactionManager" />
<!-- 配置事务管理器 -->
    <bean id="transactionManager"
          class="org.springframework.jdbc.datasource.DataSourceTransactionManager"
          p:dataSource-ref="dataSource" />

    <!-- 指明使用注解的方式来管理事务 -->
    <tx:annotation-driven transaction-manager="transactionManager" />

然后我们在需要加事务管理的Service中添加@Transactional注解,我们就会在日志中看到如下效果了:

Releasing transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@368214f9]
[DEBUG][2017/08/22 10:38:34132][org.mybatis.spring.SqlSessionUtils$SqlSessionSynchronization.beforeCommit(SqlSessionUtils.java:284)]
Transaction synchronization committing SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@368214f9]
[DEBUG][2017/08/22 10:38:34132][org.mybatis.spring.SqlSessionUtils$SqlSessionSynchronization.beforeCompletion(SqlSessionUtils.java:310)]
Transaction synchronization deregistering SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@368214f9]
[DEBUG][2017/08/22 10:38:34133][org.mybatis.spring.SqlSessionUtils$SqlSessionSynchronization.beforeCompletion(SqlSessionUtils.java:315)]
Transaction synchronization closing SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@368214f9]
[DEBUG][2017/08/22 10:38:34133][org.springframework.transaction.support.AbstractPlatformTransactionManager.processCommit(AbstractPlatformTransactionManager.java:759)]
Initiating transaction commit

但是用这个方法并没有解决我的问题,通过以下方法解决

2、我自己解决的方法

当我遇到这个异常时也在网上找解决方法,可没有解决,最后发现是自己操作的问题
在这里插入图片描述

我们都运行过sql文件 如图 ,如果我们有sql文件,都是右键运行sql文件。

可有时运行时表会跑到系统自带的数据库,如springboot-vue库,这时我们去程序操作,就会报Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@38e46e4a]

最后发现把系统数据库的表删除,重新建个数据库放表就解决问题了。这是我遇到这个异常的解决方法、希望对初学者有所帮助。

3、重新建个数据库放表就解决问题了

  • 6
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
引用中的代码段描述了在MyBatis中获取SqlSession的方法。引用中的日志信息显示了在创建新的SqlSession时的一些详细信息,包括执行的SQL语句和参数。引用中的描述是关于在操作系统自带的数据库时可能会遇到的问题。 问题: "Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession"是什么意思? 回答: "Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession"意味着一个非事务性的SqlSession正在被关闭。当使用MyBatis进行数据库操作时,SqlSession是一个关键的对象,它用于执行SQL语句并管理数据库连接。在使用完SqlSession后,应该关闭它以释放资源。在这个特定的日志信息中,显示的是一个非事务性的SqlSession正在被关闭。这可能是由于某些操作没有在事务中执行导致的,或者是因为在操作系统自带的数据库时遇到了一些问题。123 #### 引用[.reference_title] - *1* *2* [mybatis:Creating a new SqlSession Closing non transactional SqlSession](https://blog.csdn.net/yzh_1346983557/article/details/115099740)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}} ] [.reference_item] - *3* [解决Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlS..(22.11.20)](https://blog.csdn.net/qq_48602526/article/details/127951451)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}} ] [.reference_item] [ .reference_list ]
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值