spring mybatis整合事务不起作用

阅读更多

今天同事在测试spring事务回滚的时候,发现事务回滚不了,使用的spring+mybatis,配置如下:


	
	
	
	
	
	
	
	
	
	
	
	
	
	



	
	
	
	
	
	
	
	



	
	
	
	

	

	


 配置文件中也添加了注解扫描,使用aspectj实现动态代理,classpath中也添加了asm、aspectj相关的jar包,但还是不起作用,该配置的都配置了。

启动日志中发现有以下输出:

10:49:45.243 [Thread-10] DEBUG o.s.jdbc.datasource.DataSourceUtils - Fetching JDBC Connection from DataSource
10:49:45.246 [Thread-11] DEBUG org.mybatis.spring.SqlSessionUtils - Creating a new SqlSession
10:49:45.246 [Thread-11] DEBUG org.mybatis.spring.SqlSessionUtils - SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@4933e6d6] was not registered for synchronization because synchronization is not active
10:49:45.246 [Thread-10] DEBUG o.m.s.t.SpringManagedTransaction - JDBC Connection [com.mchange.v2.c3p0.impl.NewProxyConnection@6a437f45] will not be managed by Spring

 应该是连接没有被spring管理到。找了很长时间,没找到原因。

后来重新整了个环境,相似的配置,新环境却可以。把两个环境对比了下,一点点对比,同事的环境是javaFX,用来做桌面开发的,交给spring管理的业务类实现了java8中的函数式接口,后来在新环境中测试了一下,定义了一个函数式接口,将新环境的业务类实现这个函数式接口,发现启动的时候报错了,spring没扫描到业务类,不知道为嘛扫描不到。问题找到了,也解决了,但是不知道为嘛实现函数式接口的业务类无法被扫描,正常情况下函数式接口也不是用来被实现的,而是方便使用lambda表达式操作的,以后得注意。

你可能感兴趣的:(spring,mybatis,事务)