数据库更新锁:使用种子表获取自增流水号时,避免高并发访问种子字段引起获取到重复流水号的问题

获取流水号的方式

在数据库应用开发中,比如订单业务中,需要使用到流水号,即每次获取自增一次后的值。

一般有两种方式,

1.获取订单表中当前最大值加1,此方式每次都需要MAX流水号,大数据表时效率不高,不推荐使用。

2.创建种子表,将流水号字段放到该表中,每次获取表中的字段值,加1得到新的流水号,再把新值更新回表中,提供给下一次生成使用。

方法2相对方法1更推荐使用。

数据表效果如下:

问题

使用种子表方式是先获取字段值再加1,如果高并发情况下,可能会遇到获取到的值是另一个线程已经获取到但还未更新回数据库的过时流水号,

即读取到脏数据,此时就会导致两个线程获取到的流水号是一样的问题。

 

解决方案

将获取和自增的两个过程放到事务代码中执行,并且获取前先执行更新的操作,目的是为了在事务提交前先获取更新锁,在这期间其他线程就无法写入数据,保证了更新前这个值是正确值。

至于更新的内容,你可以更新任意值,只要是更新操作即可。

获取流水号,自增,最后提交事务,完成。

 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

奋斗鱼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值