执行数据库更新update操作的时候数据库卡死了
问题分析
一般都是数据库事务未提交,导致update或者delete卡死。
解决办法
- 在执行完更新或删除后,记得将事务提交commit;
- 找到数据库客户端,执行commit操作。
如果还不行。 那么应该是数据库在执行数据操作失败 or 事务未提交 之后,将需要执行的sql语句锁死了。
过程复现和解决
通过如下命令查看数据库的自动提交状态
show variables like 'autocommit';
通过SQL设置数据库自动自动提交为关闭
set autocommit=off;
set autocommit=0;
表中数据如下: 打开两个窗口分别执行update操作
update car set color ='银色' where id = 1;
update car set color ='红色' where id = 1;
查询正在执行的事务:
SELECT * FROM information_schema.INNODB_TRX;
根据图中事务的线程ID(trx_mysql_thread_id)可以看出对应的mysql 线程:一个1084 (update正在等待锁)另一个是1089(update 正在执行 没有提交事务)
可以使用mysql命令杀掉线程:kill 线程id
kill 1089;
期间如果并未杀掉持有锁的线程:则第二个update语句会提示等待锁超时。 相关命令:
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS;
select * from information_schema.`PROCESSLIST`(show processlist;)
扩展
oracle的操作方式:
- 查询锁定记录
SELECT s.sid, s.serial
- 删除锁定记录
ALTER system KILL session 'SID,serial#';
呜啦啦啦啦 看官喜欢的话点赞收藏或者关注一下吧
|