日常排雷--数据库异常的处理

碰到一个业务,给用户充值修改余额,并且插入记录表.

在进行多线程测试的时候,因为记录表是用户名和时间做的唯一性约束,单位时间里只能插入一条记录,造成数据不统一,所以加了事务回滚.

项目基于springboot 做的,本以为直接@Transactional就可以了,测试之后发现不行!

之后各种排雷,多次测试,找到了一个正确的方法:

因为在Repository类上面有@Repository注解,默认自动处理数据库异常,导致数据库异常没抛出来,后来加上try catch.手动抛了RuntimeException,这样就可以了!

还有一个就是 一般的事务中  对于error 和RuntimeException 是不需要通过throw 和try catch进行捕获的,不然会导致异常被捕获,无法进行回滚,对于checked必须由throw抛出或者try catch捕获,

猜你喜欢

转载自blog.csdn.net/qq_41397689/article/details/87931169