并发修改同一条数据的处理办法

1.产生数据不一致原因及解决办法

https://www.php.cn/faq/568665.html

2.不用锁, 旧值判断重试机制

/*
* 不用锁, 旧值判断重试机制, 其实也是变相的行级锁。这种方案会遇到一个ABA问题,加个时间戳或版本号字段即可解决,主要是这个思路。
* 优点:所有请求不用排队,并发修改同一个id的请求保证都能成功,这种方案适合虽然总的并发量特别大,但是是均匀分布到不同数据上的,针对单条数据的并发量中等以下。
* 缺点:其实是将并发压力转移到数据库,如果你的业务针对单条数据的并发量特别大,而数据库配置比较低的话,则很可能遇到数据库性能瓶颈。
* **/
public void Update3(int id, int variation)
{
   var rd = new Random();
   while (true)
   {
       var sql1 = "select money from table1 where id = @id";
       var oldMoney = db.Excute(sql1, new { id });
       var newMoney = oldMoney + variation;
       var sql2 = "update table1 set money = @newMoney where id = @id and money = @oldMoney";
       var c = db.Excute(sql2, new { newMoney, id, oldMoney });
       //如果受影响行数大于0就是更新成功了,这里也可以将修改前和后的值返回出去
       if (c > 0) break;
       //否则就是数据已经被别人更新过了,随机等待几百毫秒重试
       else Task.Delay(rd.Next(100, 1500)).Wait();
   }
}

参考:https://blog.csdn.net/V_WeiXiao/article/details/134638782

  • 12
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL的并发更新同一记录,是指多个并发事务同时对同一条记录进行更新操作的情况。 MySQL通过使用锁机制来确保并发操作的一致性和数据完整性。在并发更新同一记录的情况下,MySQL会自动将其中一个事务加锁,阻止其他事务对该记录进行修改,直到当前事务完成或者释放锁。 MySQL提供了两种类型的锁:共享锁和排他锁。 共享锁(Shared Lock)也称为读锁,多个事务可以同时持有共享锁,用于并发读取相同的记录。获得共享锁的事务之间互不干扰,可以同时读取数据。 排他锁(Exclusive Lock)也称为写锁,只有一个事务可以持有排他锁,用于对记录进行修改。其他事务在当前事务持有排他锁期间无法读取或修改该记录。 当多个事务同时更新一条记录时,会存在一定的并发控制问题。MySQL通过使用锁机制和事务隔离级别来解决这些问题。 在事务隔离级别为读已提交(Read Committed)或可重复读(Repeatable Read)的情况下,MySQL会根据事务的隔离级别自动选择适当的锁机制,确保并发更新同一记录时数据的一致性。 如果并发更新一条记录的事务操作过于频繁,可能会导致锁竞争,从而降低数据库的处理性能。为了提高并发性能,可以考虑调整事务隔离级别,或者使用更细粒度的锁策略,例如行级锁。 总之,MySQL通过合理的锁机制和事务隔离级别来处理并发更新同一记录的情况,确保数据的一致性和完整性。在实际使用中,需要根据具体的业务需求和性能要求选择适当的锁机制和事务隔离级别。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值