如何缩短SQL触发器引起的表锁定时间?

2026-05-06 19:380阅读0评论SEO基础
  • 内容介绍
  • 相关推荐

本文共计1029个文字,预计阅读时间需要5分钟。

如何缩短SQL触发器引起的表锁定时间?

触发展器本身不加锁,但其执行被绑定在主事务中——即锁时间过长,取决于整个事务何时结束,而不是触发展器跑完就释放。

触发器锁表时间 = 主事务生命周期

你执行一条 UPDATE t1 SET x=1 WHERE id=100,哪怕只改一行,只要它后面跟着一个 AFTER UPDATE 触发器,且该触发器里又执行了 INSERT INTO log_tableUPDATE t2,那这一整条链路的所有锁(包括 t1 的行锁、t2 的行锁、log_table 的插入意向锁)都会一直挂着,直到你显式 COMMIT 或连接断开回滚。

常见错误现象:SHOW PROCESSLIST 显示状态是 UpdatingWaiting for table metadata lock,同时 SELECT ... FOR UPDATEALTER TABLE 全部卡住。

阅读全文

本文共计1029个文字,预计阅读时间需要5分钟。

如何缩短SQL触发器引起的表锁定时间?

触发展器本身不加锁,但其执行被绑定在主事务中——即锁时间过长,取决于整个事务何时结束,而不是触发展器跑完就释放。

触发器锁表时间 = 主事务生命周期

你执行一条 UPDATE t1 SET x=1 WHERE id=100,哪怕只改一行,只要它后面跟着一个 AFTER UPDATE 触发器,且该触发器里又执行了 INSERT INTO log_tableUPDATE t2,那这一整条链路的所有锁(包括 t1 的行锁、t2 的行锁、log_table 的插入意向锁)都会一直挂着,直到你显式 COMMIT 或连接断开回滚。

常见错误现象:SHOW PROCESSLIST 显示状态是 UpdatingWaiting for table metadata lock,同时 SELECT ... FOR UPDATEALTER TABLE 全部卡住。

阅读全文