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

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

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

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

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

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

 

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值