ToB企服应用市场:ToB评测及商务社交产业平台

标题: 彻底讲透:高并发场景下,MySQL处理并发修改同一行数据的安全方法 [打印本页]

作者: 东湖之滨    时间: 2024-6-11 12:13
标题: 彻底讲透:高并发场景下,MySQL处理并发修改同一行数据的安全方法
在高并发场景下,MySQL处理并发修改同一行数据的安全方法紧张有以下几种:
联合实际应用场景和数据库特性选择符合的并发控制策略,才气既保证数据的一致性,又分身系统的高性能。

举例子:

熊二:光头强,咱们现在这小卖部的生意火爆得不可,有时间同时很多多少人下单买同一件商品,你要是用MySQL更新库存的时间,万一被别人插队给改了咋整?
光头强:嘿,那不是乱套了吗?我可不想有人空手套白狼把咱的商品都给“抢”光了!
熊二:没错!为了制止这种环境,我给你支几招。首先,可以试试悲观锁,就像超市收银台排队结账一样。
光头强:怎么个排法?
熊二:就是在你预备修改库存前,先用SELECT ... FOR UPDATE跟数据库说:“嘿,我要改这个商品的库存,你们其他人先别动,等我改完了再轮到你们。”
  1. START TRANSACTION;
  2. SELECT stock FROM products WHERE product_id = ? FOR UPDATE;
  3. -- 检查并计算新的库存值
  4. UPDATE products SET stock = new_stock WHERE product_id = ?;
  5. COMMIT;
复制代码
光头强:哦,懂了,就是先占坑再操作。那还有别的招吗?
熊二:固然有,还有一种叫乐观锁,这就像是每件商品都有个“标签”,每次改库存之前都要看看这个标签有没有变。
光头强:啥标签?
熊二:在数据库里加一个版本号字段,比如version。每次修改时,不光要更新库存,还要把版本号+1。
  1. UPDATE products
  2. SET stock = new_stock, version = version + 1
  3. WHERE product_id = ? AND version = current_version;
复制代码
如果更新失败(受影响行数为0),那就分析期间有人捷足先登,这时间你就重新获取最新数据,再尝试更新。
光头强:哈哈,这招更像玩捉迷藏,谁动作快谁就赢!
熊二:对啊,各有各的好处,具体选哪一招,就得看咱小卖部的实际需求和性能瓶颈了!

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4