如何缩短SQL触发器引起的表锁定时间?
- 内容介绍
- 相关推荐
本文共计1029个文字,预计阅读时间需要5分钟。
触发展器本身不加锁,但其执行被绑定在主事务中——即锁时间过长,取决于整个事务何时结束,而不是触发展器跑完就释放。
触发器锁表时间 = 主事务生命周期
你执行一条 UPDATE t1 SET x=1 WHERE id=100,哪怕只改一行,只要它后面跟着一个 AFTER UPDATE 触发器,且该触发器里又执行了 INSERT INTO log_table 或 UPDATE t2,那这一整条链路的所有锁(包括 t1 的行锁、t2 的行锁、log_table 的插入意向锁)都会一直挂着,直到你显式 COMMIT 或连接断开回滚。
常见错误现象:SHOW PROCESSLIST 显示状态是 Updating 或 Waiting for table metadata lock,同时 SELECT ... FOR UPDATE、ALTER TABLE 全部卡住。
本文共计1029个文字,预计阅读时间需要5分钟。
触发展器本身不加锁,但其执行被绑定在主事务中——即锁时间过长,取决于整个事务何时结束,而不是触发展器跑完就释放。
触发器锁表时间 = 主事务生命周期
你执行一条 UPDATE t1 SET x=1 WHERE id=100,哪怕只改一行,只要它后面跟着一个 AFTER UPDATE 触发器,且该触发器里又执行了 INSERT INTO log_table 或 UPDATE t2,那这一整条链路的所有锁(包括 t1 的行锁、t2 的行锁、log_table 的插入意向锁)都会一直挂着,直到你显式 COMMIT 或连接断开回滚。
常见错误现象:SHOW PROCESSLIST 显示状态是 Updating 或 Waiting for table metadata lock,同时 SELECT ... FOR UPDATE、ALTER TABLE 全部卡住。

