解决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@38e46e4a]异常 1、我自己解决的方法 作为初学者,当我遇到这个异常时也在网上找解决方法,可都没有解决,最后发现是自己操作的问题 我们都运行过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 commit3、引用其它作者方法 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 |