解决Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@38e46e4

解决Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@38e46e4a]异常

1、我自己解决的方法

作为初学者,当我遇到这个异常时也在网上找解决方法,可都没有解决,最后发现是自己操作的问题

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

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

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

 

2、网上其它作者的方法

在我们没有开启事务的时候,如果使用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" />


然后我们在需要加事务管理的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

3、引用其它作者方法

Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@376cd750]

怀疑配置有问题导致事务不生效 测试了一下果然事务没有生效 不会回滚

仔细检查了下配置文件 发现重复扫描的问题 

因为spring的context是父子容器,所以会产生冲突,由ServletContextListener产生的是父容器,springMVC产生的是子容器,子容器Controller进行扫描装配时装配了@Service注解的实例,而该实例理应由父容器进行初始化以保证事务的增强处理,所以此时得到的将是原样的Service(没有经过事务加强处理,故而没有事务处理能力。 

在springMvc的配置文件中扫描了service的所有注解

应该改为 applicationContext.xml只扫描service层和dao层,springMvc.xml只扫描controller层。

但是不清楚该项目的具体结构和内容 所以为单独解决事务不生效问题 在springMvc的配置文件中将service包中的

org.springframework.stereotype.Service注解排除掉

 

在applicationContext.xml配置文件中将

org.springframework.stereotype.Controller注解排除掉

同时service层代码声明

@Transactional(rollbackFor = Exception.class)

 

 

以上三处修改完毕之后重启项目 

  • 14
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 12
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值