碰到一个业务,给用户充值修改余额,并且插入记录表.
在进行多线程测试的时候,因为记录表是用户名和时间做的唯一性约束,单位时间里只能插入一条记录,造成数据不统一,所以加了事务回滚.
项目基于springboot 做的,本以为直接@Transactional就可以了,测试之后发现不行!
之后各种排雷,多次测试,找到了一个正确的方法:
因为在Repository类上面有@Repository注解,默认自动处理数据库异常,导致数据库异常没抛出来,后来加上try catch.手动抛了RuntimeException,这样就可以了!
还有一个就是 一般的事务中 对于error 和RuntimeException 是不需要通过throw 和try catch进行捕获的,不然会导致异常被捕获,无法进行回滚,对于checked必须由throw抛出或者try catch捕获,