blog:spring:transaction:missing

Spring事务失效

  • Bean没有纳入Spring容器管理
  • 自调用,即调用当前类的方法,比如用this调用当前类的方法
  • 异常没有跑出,被try catch了
  • 跑出的不是RuntimeException,且没有指定rollbackFor=异常类型
  • 事务方法不是publish的
    • spring的事务注解@Transactional只能放在public修饰的方法上才起作用,如果放在其他非public(private,protected)方法上,虽然不报错,但是事务不起作用
  • 事务方法内启动新线程进行异步操作
  • @Transactional注解的propagation属性设置错误
  • 数据库不支持事务
    • 如使用mysql且引擎是MyISAM,则事务会不起作用,原因是MyISAM不支持事务,可以改成InnoDB引擎
  • 动态数据源,切换数据源的话会导致事务失效
  • 如果采用spring+spring mvc,则context:component-scan重复扫描问题可能会引起事务失败。
    • 如果spring和mvc的配置文件中都扫描了service层,那么事务就会失效。
    • 原因:因为按照spring配置文件的加载顺序来讲,先加载springmvc配置文件,再加载spring配置文件,我们的事物一般都在srping配置文件中进行配置,如果此时在加载srpingMVC配置文件的时候,把servlce也给注册了,但是此时事物还没加载,也就导致后面的事物无法成功注入到service中。所以把对service的扫描放在spring配置文件中或是其他配置文件中。
  • 在类A里面有方法a 和方法b, 然后方法b上面用 @Transactional加了方法级别的事务,在方法a里面 调用了方法b, 方法b里面的事务不会生效。原因是在同一个类之中,方法互相调用,切面无效 ,而不仅仅是事务。这里事务之所以无效,是因为spring的事务是通过aop实现的。


  • blog/spring/transaction/missing.txt
  • 最后更改: 2022/04/21 07:07
  • okami