这篇文章给大家分享的是有关如何解决SpringBoot内部调用事务不起作用的问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
场景
我在这里模拟一个场景,大概的调用方式就如下面的代码这样。
@Override @Transactional(rollbackFor = RuntimeException.class) public void insertUser(User user) { userMapper.insertUser(user); throw new RuntimeException(""); } /** * 内部调用新增方法 * * @param user */ @Override public void invokeInsertUser(User user) { this.insertUser(user); }
原因
AOP使用的是动态代理的机制,它会给类生成一个代理类,事务的相关操作都在代理类上完成。内部方式使用this调用方式时,使用的是实例调用,并没有通过代理类调用方法,所以会导致事务失效。
解决办法
方法一 引入自身bean
在类内部通过@Autowired
将本身bean
引入,然后通过调用自身bean
,从而实现使用AOP
代理操作。
注入自身bean
@Autowired @Lazy private UserService service;
修改invokeInsertUser
方法
/** * 解决方法一 在bean中将自己注入进来 * @param user */ @Override public void invokeInsertUser(User user) { this.service.insertUser(user); }
方法二 通过ApplicationContext引入bean
通过ApplicationContext
获取bean,通过bean调用内部方法,就使用了bean的代理类。
注入ApplicationContext
@Autowired ApplicationContext applicationContext;
修改invokeInsertUser
方法
/** * 解决方法二 通过applicationContext获取到bean * @param user */ @Override public void invokeInsertUser(User user) { ((UserService)applicationContext.getBean("userService")).invokeInsertUser(user); }
方法三 通过AopContext获取当前类的代理类
通过AopContext
获取当前类的代理类,直接通过代理类调用方法
在引导类上添加@EnableAspectJAutoProxy(exposeProxy=true)
注解
修改invokeInsertUser
方法
/** * 解决方法三 通过applicationContext获取到bean * * @param user */ @Override public void invokeInsertUser(User user) { ((UserService) AopContext.currentProxy()).invokeInsertUser(user); }
感谢各位的阅读!关于“如何解决SpringBoot内部调用事务不起作用的问题”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。