美文网首页
当@Transactional不起作用如何排查问题

当@Transactional不起作用如何排查问题

作者: 晨什么呀 | 来源:发表于2018-09-27 12:26 被阅读0次

    可以按照以下几个步骤逐一确认:

    1、首先要看数据库本身对应的库、表所设置的引擎是什么。MyIsam不支持事务,如果需要,则必须改为InnnoDB。

    2、@Transactional所注解的方法是否为public

    3、@Transactional所注解的方法所在的类,是否已经被注解@Service或@Component等。

    4、需要调用该方法,且需要支持事务特性的调用方是在在 @Transactional所在的类的外面。注意:类内部的其他方法调用这个注解了@Transactional的方法,事务是不会起作用的。

    5、注解为事务范围的方法中,事务的回滚仅仅对于unchecked的异常有效。对于checked异常无效。也就是说事务回滚仅仅发生在出现RuntimeException或Error的时候。

    如果希望一般的异常也能触发事务回滚,需要在注解了@Transactional的方法上,将@Transactional回滚参数设为:

    @Transactional(rollbackFor=Exception.class)
    

    相关文章

      网友评论

          本文标题:当@Transactional不起作用如何排查问题

          本文链接:https://www.haomeiwen.com/subject/dwkeoftx.html