java关于mysql的事务回滚问题(默认引擎)

**

当一个service有多条增删改sql时,需要用到事务控制。

**
1)首先,在方法或者类上加入@Transactional(rollbackFor = Exception.class)这个基本就OK了。(rollbackFor = Exception.class意思是遇到非运行期异常也回滚)
2)如果还想自己控制事务的回滚,那就使用try{}catch{}。在try中的代码做判断,不符合直接throw new RuntimeException()。如下:
在这里插入图片描述
3)然后在catch中:TransactionAspectSupport.currentTransactionStatus().setRollbackOnly()。手动回滚事务。
4)这就ok了。如果使用mysql的其他引擎,就要查看此引擎是否支持事务。
5)也可以使用:
Object rollbackPoint=TransactionAspectSupport.currentTransactionStatus().createSavepoint();设置一个回滚点;
再TransactionAspectSupport.currentTransactionStatus().rollbackToSavepoint(rollbackPoint);回滚到rollbackPoint。(第五条没测)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值