服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Mysql - MySQL数据库执行Update卡死问题的解决方法

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

2022-10-25 15:54共饮一杯无 Mysql

最近开发的时候debug到一条update的sql语句时程序就不动了,然后我就在plsql上试了一下,发现plsql一直在显示正在执行,等了好久也不出结果,下面这篇文章主要给大家介绍了关于MySQL数据库执行Update卡死问题的解决方法,需要的朋友可以参

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

问题分析

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

解决办法

  1. 在执行完更新或删除后,记得将事务提交commit;
  2. 找到数据库客户端,执行commit操作。

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

过程复现和解决

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

?
1
show variables like 'autocommit';

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

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

表中数据如下:

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

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

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

查询正在执行的事务:

?
1
SELECT * FROM information_schema.INNODB_TRX;

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

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

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

?
1
kill 1089;

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

MySQL数据库执行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

延伸 · 阅读

精彩推荐
  • MysqlMYSQL必知必会读书笔记第五章之排序检索数据

    MYSQL必知必会读书笔记第五章之排序检索数据

    本文给大家分享mysql必会必知读书笔记第五章之排序检索数据,小编认为非常具有参考价值,特此分享到脚本之家平台供大家参考...

    自然鸟神4882020-06-07
  • Mysql分享MySQL的自动化安装部署的方法

    分享MySQL的自动化安装部署的方法

    线上的MySQL一般都采用源码编译,虽然MySQL的源码编译挺简单的,但是试想一下,如果你有几百台服务器同时要安装MySQL,难道你还一台台去手动编译、编写...

    hebedich4002020-04-08
  • MysqlMySQL 不允许从远程访问的解决方法

    MySQL 不允许从远程访问的解决方法

    MySQL 不允许从远程访问的原因有很多除了下面的方法,还有需要看服务器安全设置禁止访问本机的3306端口。 ...

    mysql教程网9122019-11-05
  • Mysql详解mysql触发器trigger实例

    详解mysql触发器trigger实例

    这篇文章主要为大家介绍了mysql触发器trigger实例 ,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助...

    周伯通的麦田5892022-02-16
  • MysqlMySQL压力测试方法 如何使用mysqlslap测试MySQL的压力?

    MySQL压力测试方法 如何使用mysqlslap测试MySQL的压力?

    生产服务器用LANMP组合和用LAMP组合有段时间了,总体来说都很稳定。但出现过几次因为MYSQL并发太多而挂掉,一直想对MYSQL做压力测试。刚看到一篇介绍MY...

    MYSQL教程网2982020-06-09
  • Mysql在一台服务器上安装两个或多个mysql的实现步骤

    在一台服务器上安装两个或多个mysql的实现步骤

    这篇文章给大家介绍如何在一台服务器上安装两个或多个mysql的实现步骤,有需要的朋友们可以参考学习,下面跟着小编一起来看看吧。 ...

    daisy6612020-06-22
  • MysqlMySQL删除外键问题小结

    MySQL删除外键问题小结

    mysql删除外键抱错Error on rename of ./ruler/test2child to ./ruler/#sql2-298-92 (errno: 152),怎么回事,有好的方法可以解决吗?下面看下服务器之家小编给大家带来的解决...

    wangle100wangle3792020-06-19
  • MysqlMYSQL必知必会读书笔记第四章之检索数据

    MYSQL必知必会读书笔记第四章之检索数据

    MySQL是一种开放源代码的关系型数据库管理系统(RDBMS)。接下来通过本文给大家介绍MYSQL必知必会读书笔记第四章之检索数据,感兴趣的朋友一起学习吧 ...

    自然鸟神4562020-06-07