MySQL在事务中如何实现串行化_使用select lock in share mode查询

SELECT ... LOCK IN SHARE MODE 只阻塞其他事务的 SELECT ... FOR UPDATE 和 UPDATE/DELETE,不阻塞普通 SELECT 或其他共享锁;它允许多个事务同时读,但无法防止并发修改,需配合排他锁或原子更新使用。SELECT ... LOCK IN SHARE MODE 会阻塞哪些操作它只阻塞其他事务对同一行执行 SELECT ... FOR UPDATE 或 UPDATE/DELETE,但不阻塞普通 SELECT,也不阻塞其他事务的 SELECT ... LOCK IN SHARE MODE(可共享读锁)。换句话说,它允许多个事务同时加共享锁,但会排队等排他锁。常见错误现象:以为加了 LOCK IN SHARE MODE 就能防止并发修改,结果两个事务都读到旧值、都执行更新,造成覆盖写。这不是锁失效,而是共享锁本来就不排斥别的共享锁------你需要的是排他锁,或者配合 UPDATE 原子操作。使用场景:适合"读取后校验,再决定是否更新"的流程,比如库存预占(查剩余量 ≥1 → 再扣减),但必须确保后续有 UPDATE 或显式等待逻辑注意隔离级别:在 REPEATABLE READ 下,该语句会加间隙锁(gap lock),可能意外锁住不存在的行;若只想锁命中行,需确认 where 条件走唯一索引性能影响:锁粒度是行级,但若条件不走索引,会退化为表锁,直接拖慢整个表的写操作为什么有时候 LOCK IN SHARE MODE 不生效最常见原因是事务没开启,或自动提交开着:SET autocommit = 1 下,每条语句都是独立事务,锁在语句结束就释放,根本起不到保护作用。另一个隐蔽坑是:MySQL 的 LOCK IN SHARE MODE 在主从复制中默认是 statement-based(SBR),而共享锁不记录在 binlog,从库不会复现锁行为,导致主从一致性逻辑错乱。如果依赖锁做业务控制,务必用 ROW 格式复制,并确认从库也启用相同隔离级别。检查方式:执行 SELECT @@autocommit 和 SELECT @@tx_isolation,确保为 0 和 REPEATABLE-READ参数差异:innodb_lock_wait_timeout 控制等待超时,默认 50 秒,线上建议设为 5--10 秒,避免长等待拖垮连接池不要和 SELECT ... FOR UPDATE 混用在同一事务里,除非明确需要升级锁;否则可能引发死锁,尤其当多行锁顺序不一致时替代方案:什么时候该用 SELECT FOR UPDATE 而不是 LOCK IN SHARE MODE当你读完数据后几乎必然要更新(比如查余额 → 扣款),直接用 SELECT ... FOR UPDATE 更安全。它加的是排他锁,天然阻止其他事务读写同一行,省去锁升级步骤,也规避了"先共享再更新"中间的时间窗口。 There's An AI For That 全球领先的 AI 聚合器,收集10,225个AI工具,可用于超过2,548个任务。

相关推荐
曲幽10 小时前
FastAPI 身份验证总踩坑?这份 FastAPI Users “避坑指南”请收好
python·fastapi·web·jwt·oauth2·user·authentication
素材积累11 小时前
博士后出站来深可申请的项目补贴等
数据库
装不满的克莱因瓶11 小时前
掌握 RNN 与 LSTM 模型结构
人工智能·python·rnn·深度学习·神经网络·ai·lstm
何以解忧,唯有..11 小时前
Python包管理工具pip:从入门到精通
开发语言·python·pip
金銀銅鐵11 小时前
用 Tkinter 实现简单的猜数字游戏
后端·python
copyer_xyf12 小时前
Python 模块与包的导入导出
前端·后端·python
_1_712 小时前
SQL Server 磁盘满了 收缩日志
数据库·sqlserver
ice81303318112 小时前
【Python】Matplotlib折线图绘制
开发语言·python·matplotlib
copyer_xyf12 小时前
Python venv 虚拟环境
前端·后端·python
basketball61612 小时前
Redis基础:1. Redis介绍
数据库·redis·缓存