**
当一个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。(第五条没测)