MySQL数据库执行Update卡死问题的解决方法

作者:共饮一杯无 时间:2024-01-15 16:06:50 

执行数据库更新update操作的时候数据库卡死了

问题分析

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

解决办法

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

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

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

过程复现和解决

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

show variables like 'autocommit';

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

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

表中数据如下:

MySQL数据库执行Update卡死问题的解决方法

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

update car set color ='银色' where id = 1;
update car set color ='红色' where id = 1;

查询正在执行的事务:

SELECT * FROM information_schema.INNODB_TRX;

MySQL数据库执行Update卡死问题的解决方法

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

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

kill 1089;

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

MySQL数据库执行Update卡死问题的解决方法

相关命令:

-- 查看正在锁的事务
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;

-- 查看等待锁的事务
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS;
-- 查询mysql数据库中存在的进程
select * from information_schema.`PROCESSLIST`(show processlist;)  

扩展

oracle的操作方式:

查询锁定记录

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;

删除锁定记录

ALTER system KILL session 'SID,serial#';

来源:https://blog.csdn.net/qq_35427589/article/details/123399343

标签:mysql,update,卡死
0
投稿

猜你喜欢

  • opencv模板匹配相同位置去除重复的框

    2022-03-09 04:06:14
  • Django项目实战之配置文件详解

    2023-08-13 19:28:07
  • JavaScript面向对象中的封装和继承你了解吗

    2024-06-07 16:00:16
  • Python MySQL 日期时间格式化作为参数的操作

    2024-01-12 23:52:13
  • python模拟事件触发机制详解

    2023-03-11 11:09:02
  • js常用排序实现代码

    2023-08-30 08:50:24
  • python面向对象多线程爬虫爬取搜狐页面的实例代码

    2021-11-27 21:49:39
  • Python随机生成身份证号码及校验功能

    2023-03-20 08:30:47
  • python自制简易mysql连接池的实现示例

    2023-04-14 20:23:55
  • Nodejs中调用系统命令、Shell脚本和Python脚本的方法和实例

    2024-05-13 09:29:17
  • python实现图片筛选程序

    2021-06-25 07:24:32
  • 15款Python编辑器的优缺点,别再问我“选什么编辑器”啦

    2021-10-06 12:37:55
  • Django之第三方平台QQ授权登录的实现

    2023-04-27 16:37:06
  • tensorflow之自定义神经网络层实例

    2022-05-26 07:05:27
  • python使用rsa加密算法模块模拟新浪微博登录

    2022-06-04 13:36:19
  • Python中设置变量访问权限的方法

    2023-09-13 15:42:15
  • SQL2000 事务回滚问题探讨

    2024-01-26 19:58:37
  • python怎么提高计算速度

    2021-06-09 17:04:42
  • 网页视频播放器程序代码(通用代码),支持avi,wmv,asf,mov,rm,ra,ram等

    2008-07-16 11:56:00
  • tensorflow2.0教程之Keras快速入门

    2022-05-11 22:34:17
  • asp之家 网络编程 m.aspxhome.com