MySQL数据库执行Update卡死问题怎么解决(mysql,update,开发技术)

时间:2024-05-05 21:08:47 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

问题分析

一般都是数据库事务未提交,导致update或者delete卡死。

解决办法

  1. 在执行完更新或删除后,记得将事务提交commit;

  2. 找到数据库客户端,执行commit操作。

如果还不行。 那么应该是数据库在执行数据操作失败 or 事务未提交 之后,将需要执行的sql语句锁死了。

过程复现和解决

通过如下命令查看数据库的自动提交状态

showvariableslike'autocommit';

通过SQL设置数据库自动自动提交为关闭

--on为开启,off为关闭setautocommit=off;--或者1为开启,0为关闭setautocommit=0;

表中数据如下:

MySQL数据库执行Update卡死问题怎么解决

打开两个窗口分别执行update操作

updatecarsetcolor='银色'whereid=1;updatecarsetcolor='红色'whereid=1;

查询正在执行的事务:

SELECT*FROMinformation_schema.INNODB_TRX;

MySQL数据库执行Update卡死问题怎么解决

根据图中事务的线程ID(trx_mysql_thread_id)可以看出对应的mysql 线程:一个1084 (update正在等待锁)另一个是1089(update 正在执行 没有提交事务)

可以使用mysql命令杀掉线程:kill 线程id

kill1089;

期间如果并未杀掉持有锁的线程:则第二个update语句会提示等待锁超时。

MySQL数据库执行Update卡死问题怎么解决

相关命令:

--查看正在锁的事务SELECT*FROMINFORMATION_SCHEMA.INNODB_LOCKS;--查看等待锁的事务SELECT*FROMINFORMATION_SCHEMA.INNODB_LOCK_WAITS;--查询mysql数据库中存在的进程select*frominformation_schema.`PROCESSLIST`(showprocesslist;)

扩展

oracle的操作方式:

查询锁定记录

SELECTs.sid,s.serial#FROMv$locked_objectlo,dba_objectsao,v$sessionsWHEREao.object_id=lo.object_idANDlo.session_id=s.sid;

删除锁定记录

ALTERsystemKILLsession'SID,serial#';
 </div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
本文:MySQL数据库执行Update卡死问题怎么解决的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:Laravel中permission权限管理的扩展包怎么用下一篇:

7 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18