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

您所在的位置:网站首页 c加加异常处理 解决Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@38e46e4

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

2023-10-24 11:21| 来源: 网络整理| 查看: 265

解决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。

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

 

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

 

 

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



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3