MySQL数据库执行Update卡死问题的解决方法
执行数据库更新update操作的时候数据库卡死了
问题分析
一般都是数据库事务未提交,导致update或者delete卡死。
解决办法
- 在执行完更新或删除后,记得将事务提交commit;
- 找到数据库客户端,执行commit操作。
如果还不行。 那么应该是数据库在执行数据操作失败 or 事务未提交 之后,将需要执行的sql语句锁死了。
过程复现和解决
通过如下命令查看数据库的自动提交状态
?1 | show variables like 'autocommit' ; |
通过SQL设置数据库自动自动提交为关闭
?1 2 3 4 | -- on为开启,off为关闭 set autocommit= off ; -- 或者1为开启,0为关闭 set autocommit=0; |
表中数据如下:
打开两个窗口分别执行update操作
?1 2 | update car set color = '银色' where id = 1; update car set color = '红色' where id = 1; |
查询正在执行的事务:
?1 | SELECT * FROM information_schema.INNODB_TRX; |
根据图中事务的线程ID(trx_mysql_thread_id)可以看出对应的mysql 线程:一个1084 (update正在等待锁)另一个是1089(update 正在执行 没有提交事务)
可以使用mysql命令杀掉线程:kill 线程id
?1 | kill 1089; |
期间如果并未杀掉持有锁的线程:则第二个update语句会提示等待锁超时。
相关命令:
?1 2 3 4 5 6 7 | -- 查看正在锁的事务 SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS; -- 查看等待锁的事务 SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS; -- 查询mysql数据库中存在的进程 select * from information_schema.`PROCESSLIST`(show processlist;) |
扩展
oracle的操作方式:
查询锁定记录
?1 | SELECT s.sid, s.serial# FROM v$locked_object lo, dba_objects ao, v$session s WHERE ao.object_id = lo.object_id AND lo.session_id = s.sid; |
删除锁定记录
?1 | ALTER system KILL session 'SID,serial#' ; |
总结
到此这篇关于MySQL数据库执行Update卡死问题解决的文章就介绍到这了,更多相关MySQL执行Update卡死内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://blog.csdn.net/qq_35427589/article/details/123399343
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。