事务失效解决

项目中遇到一个问题:在文件上传做处理的时候,原本所有的业务都在一个事务中,包括上传文件和在数据库中添加文件信息,但是后面考虑到上传文件会有网络问题,会造成事务占用的时间会很长,就造成占用数据库资源很长,因此只对数据库操作进行@Transactional,但是后面经过排查mysql的事务没有生效。

原因:非事务方法A调用事务B引起事务失效

因为spring采用动态代理机制来实现事务控制,代理对象在执行此方法前会先开启事务,调用原始对象的此方法,最后提交事务。而原始对象在去调用方法时,不会再触发代理,因此造成了事务失效。

解决方案:

1、把方法B抽离到另外一个XXService中,并且在这个Service中注入XXService,使用XXService调用方法B;(自己调用自己,这种方式不优雅且要产生很多冗余文件,看起来很烦,实际开发中不建议这么做)
2、通过在方法内部获得当前类代理对象的方式,通过代理对象调用方法B(动态代理最终都是要调用原始对象的,而原始对象在去调用方法时,是不会再触发代理了,所以我们就使用代理对象来调用,就会触发事务)
①.使用 ApplicationContext 上下文对象获取该对象;
②.使用 AopContext.currentProxy() 获取代理对象,但是需要配置exposeProxy=true
建议使用的是第二种解决方案,具体操作如下:
springboot启动类加上注解:@EnableAspectJAutoProxy(exposeProxy = true)

     //获取代理对象
    SysUserService proxyObj = (SysUserService) AopContext.currentProxy();
    //用代理对象调用事务方法  被调用方法加了事务注解
    proxyObj.insertUser(user);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值