今天遇到 spring 事务不回滚问题。总结下缘由,方便之后拍错mysql
1. 检查你方法是否是public的。spring
2. 你的异常类型是否是unchecked异常。
若是我想check异常也想回滚怎么办,注解上面写明异常类型便可。sql
@Transactional(rollbackFor=Exception.class)
相似的还有norollbackFor,自定义不回滚的异常。数据库
3. 数据库引擎要支持事务,若是是mysql,注意表要使用支持事务的引擎,好比innodb,若是是myisam,事务是不起做用的。spa
4. 是否开启了对注解的解析component
<tx:annotation-driven transaction-manager="transactionManager" proxy-target-class="true"/>
5. spring是否扫描到你这个包,以下是扫描到org.test下面的包接口
<context:component-scan base-package="org.test" ></context:component-scan>
6.开启注解必须放在扫描包后面,必须等待扫描完成后才能开启事务,否则事务无效。事务
若是context:component-scan 配置了 屡次,以最后一个为主。最好启动注解和 扫描包放在一个文件里面。get
若是你们遇到其余问题。请提出来。一块儿解决io
切记:由于spring事物是基于类和接口的因此只能在类里面调用另外一个类里面的事物,同一个类里面调用本身类的事物方法是无效的。spring事物也不要频繁使用,在事物处理的同时操做的第一张表会被限制查看的(即被临时锁住)。数据量大的时候会有必定影响。