技术文摘
如何实现 MySQL 悲观锁
2025-01-15 02:14:58 小编
如何实现 MySQL 悲观锁
在多用户并发访问数据库的场景中,数据的一致性和完整性至关重要。MySQL 悲观锁是一种常用的并发控制机制,能有效防止数据冲突。本文将深入探讨如何在 MySQL 中实现悲观锁。
什么是悲观锁
悲观锁基于一种悲观的假设,即认为在数据处理过程中,很可能会有其他事务同时对同一数据进行修改。所以,在获取数据时就会对数据进行锁定,防止其他事务对其进行修改,直到当前事务结束释放锁。
MySQL 中实现悲观锁的方式
使用 SELECT...FOR UPDATE 语句
这是最常见的实现悲观锁的方式。例如,有一个商品库存表 product_stock,表结构包含 product_id(商品ID)和 stock(库存数量)字段。现在要对某一商品的库存进行扣减操作。
START TRANSACTION;
SELECT stock FROM product_stock WHERE product_id = 1 FOR UPDATE;
-- 这里进行库存扣减的业务逻辑,例如更新库存数量
UPDATE product_stock SET stock = stock - 1 WHERE product_id = 1;
COMMIT;
在上述代码中,SELECT...FOR UPDATE 语句会锁定 product_id 为 1 的记录。其他事务如果想要对这条记录进行修改或使用 SELECT...FOR UPDATE 语句查询,就必须等待当前事务提交或回滚。
使用 SELECT...LOCK IN SHARE MODE 语句
该语句用于获取共享锁。例如,在一个论坛系统中,要统计某一帖子的浏览量,同时确保在统计过程中,其他事务不会修改帖子的浏览量数据。
START TRANSACTION;
SELECT view_count FROM forum_post WHERE post_id = 100 LOCK IN SHARE MODE;
-- 这里进行浏览量统计等业务逻辑
COMMIT;
使用 SELECT...LOCK IN SHARE MODE 后,其他事务可以对该记录进行查询操作,但不能使用 SELECT...FOR UPDATE 语句或者执行修改操作,直到当前事务结束。
在实际应用中,要合理使用悲观锁。如果锁的粒度太大,会影响系统的并发性能;如果锁的时间过长,也可能导致其他事务长时间等待,甚至出现死锁的情况。在使用悲观锁时,需要充分考虑业务场景,权衡并发性能和数据一致性之间的关系,以确保系统的稳定运行。
- ARM v9 架构正式发布 10 年重大更新 对决英特尔 华为海思使用权存疑
- 鸿蒙开发环境 DevEco Studio 2.1 Beta3 重磅发布
- 鸿蒙开发环境 DevEco Studio 2.1 Beta3 强势发布
- 企业数据中台建设的应用范畴
- 数据库:“分库分表”的新奇玩法
- 跨平台代码的 3 种组织方式详解
- CSS3 3D 行星运转及浏览器渲染原理
- 被排名调整问题困扰一整天
- 如何根治 5G 在工业互联网中的“水土不服”
- 前端:11 款前端开发者必备神器集结
- 解决 React.useEffect() 无限循环的方法
- 2020 图灵奖授予编程回忆:Jeff Dean 的编译启蒙书令人动容
- Redis 高可用之 Sentinel 哨兵集群原理解析
- 下一代模板引擎:lit-html
- 浅议 Nodejs 中间层