此情况我前几天刚刚遭遇过,在方法上添加了注解之后一直不生效,查了资料之后才发现问题 。 因为是前辈遗留代码,所以也没多想,一步步排查数据库引擎,方法。
第一个问题是才发现方法竟然是private的,这是第一个问题,改成public之后还是不生效。继续排查才发现第二个问题,代码try。。。catch之后直接处理了,未抛出异常,所以又在catch下抛出异常。到这里基本就解决了问题。
最后我把查到的资料附在下面,可参考:
情况 1 :确认创建的 mysql 数据库表引擎是 InnoDB , MyISAM 不支持事务
情况 2 :注解到 protected , private 方法上,事务不生效,它也不会报错,不过事务设置不会起作用。
情况 3 : 在业务层捕捉异常后未向上抛出,事务不生效。
原因:在业务层手工捕捉并处理了异常( try..catch )等于把异常 “ 吃 ” 掉了, Spring 自然不知道这里有错,
更不会主动去回滚数据。推荐做法是在业务层统一抛出异常,然后在控制层统一处理。
情况 4 :遇到非检测异常时,事务不开启,也无法回滚。下方图片是异常体系
原因:因为 Spring 的默认的事务规则是遇到运行异常( RuntimeException )和程序错误( Error )才会回滚。如果
想针对非检测异常进行事务回滚,可以在 @Transactional 注解里使用 rollbackFor 属性明确指定异常。
情况 5 :不要写到接口上, spring 采用 aop 针对具体实现类做的代理实现。
情况 6 : Spring 的事务传播策略在内部方法调用时将不起作用,事务注解加到要调用方法上。