@Transational事务提交之后再处理的相关方案

场景

  我们经常会遇到一些操作为数据库,然后删除缓存的操作。然后在操作数据库的时候就加上了事务 @Transational ,结果就会遇到一些坑,就是数据库事务提交之后,查到的缓存还是旧的。

场景还原

  当事务里面sql处理执行完之后,实际上还没提交的,这时删除缓存,是已经执行的。然后这时如果别人查询旧的数据会将旧数据放到缓存里头,这下就gg了。

想法

  我们应该是执行完sql,提交事务,再进行删除缓存是吧。

方案

在黑神的文章里头讲了两个方案

1)就是把删除缓存放在事务外面
2)因为使用了@CacheEvict,所以修改@Order来修改aop执行的顺序。

介绍另一种方案

上代码

if(TransactionSynchronizationManager.isSynchronizationActive()){
			TransactionSynchronizationManager.registerSynchronization(new TransactionSynchronizationAdapter() {
				@Override
				public void afterCommit() {
					System.out.println("commit over...");
				}
			});
		}

先判断是否是在事务里头,是的话等事务提交之后进行相关操作。
在这里插入图片描述
如果是在事务外,是不起效果的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值