MySQL数据库执行Update卡死问题的解决方法
来源:脚本之家
时间:2022-12-30 17:41:34 229浏览 收藏
来到golang学习网的大家,相信都是编程学习爱好者,希望在这里学习数据库相关编程知识。下面本篇文章就来带大家聊聊《MySQL数据库执行Update卡死问题的解决方法》,介绍一下mysqlupdate、卡死,希望对大家的知识积累有所帮助,助力实战开发!
执行数据库更新update操作的时候数据库卡死了
问题分析
一般都是数据库事务未提交,导致update或者delete卡死。
解决办法
- 在执行完更新或删除后,记得将事务提交commit;
- 找到数据库客户端,执行commit操作。
如果还不行。 那么应该是数据库在执行数据操作失败 or 事务未提交 之后,将需要执行的sql语句锁死了。
过程复现和解决
通过如下命令查看数据库的自动提交状态
show variables like 'autocommit';
通过SQL设置数据库自动自动提交为关闭
-- on为开启,off为关闭 set autocommit=off; -- 或者1为开启,0为关闭 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; -- 查询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#';
总结
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于数据库的相关知识,也可关注golang学习网公众号。
声明:本文转载于:脚本之家 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
-
280 收藏
-
216 收藏
-
126 收藏
最新阅读
更多>
-
208 收藏
-
174 收藏
-
317 收藏
-
371 收藏
-
244 收藏
-
288 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习
评论列表
-
- 儒雅的宝马
- 太给力了,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢大佬分享技术贴!
- 2023-03-27 15:13:33
-
- 寂寞的哈密瓜
- 很有用,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢老哥分享技术文章!
- 2023-02-14 15:29:30
-
- 无聊的过客
- 受益颇多,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢老哥分享技术文章!
- 2023-02-03 15:12:59
-
- 不安的魔镜
- 这篇文章内容真及时,师傅加油!
- 2023-01-31 22:38:28
-
- 动听的发夹
- 真优秀,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢作者大大分享博文!
- 2023-01-31 08:50:18
-
- 激昂的小虾米
- 好细啊,mark,感谢师傅的这篇文章,我会继续支持!
- 2023-01-30 04:12:07
-
- 甜美的苗条
- 这篇技术贴真是及时雨啊,很详细,感谢大佬分享,码起来,关注作者了!希望作者能多写数据库相关的文章。
- 2023-01-17 15:03:21
-
- 重要的鲜花
- 这篇技术文章太及时了,太全面了,受益颇多,已收藏,关注作者了!希望作者能多写数据库相关的文章。
- 2023-01-17 10:01:23
-
- 眼睛大的河马
- 细节满满,码起来,感谢楼主的这篇技术文章,我会继续支持!
- 2023-01-15 19:22:23
-
- 悲凉的酒窝
- 这篇文章真是及时雨啊,博主加油!
- 2023-01-12 01:37:18
-
- 紧张的丝袜
- 这篇文章内容出现的刚刚好,细节满满,很有用,收藏了,关注大佬了!希望大佬能多写数据库相关的文章。
- 2023-01-09 19:55:17
-
- 烂漫的黑夜
- 很详细,码起来,感谢楼主的这篇文章,我会继续支持!
- 2023-01-07 05:50:53
-
- 爱听歌的砖头
- 真优秀,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢师傅分享文章!
- 2023-01-06 09:55:36
-
- 朴实的蜗牛
- 这篇文章真是及时雨啊,太全面了,真优秀,收藏了,关注作者大大了!希望作者大大能多写数据库相关的文章。
- 2023-01-05 15:36:30
-
- 敏感的奇异果
- 这篇文章内容太及时了,细节满满,太给力了,已加入收藏夹了,关注楼主了!希望楼主能多写数据库相关的文章。
- 2023-01-01 23:41:52