前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL数据库执行Update卡死问题解决

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

作者头像
共饮一杯无
发布2022-11-24 20:51:53
1.8K0
发布2022-11-24 20:51:53
举报

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

问题分析

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

解决办法

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

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

过程复现和解决

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

代码语言:javascript
复制
show variables like 'autocommit';

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

代码语言:javascript
复制
-- on为开启,off为关闭
set autocommit=off;
-- 或者1为开启,0为关闭
set autocommit=0;

表中数据如下:

在这里插入图片描述
在这里插入图片描述

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

代码语言:javascript
复制
update car set color ='银色' where id = 1;
update car set color ='红色' where id = 1;

查询正在执行的事务:

代码语言:javascript
复制
SELECT * FROM information_schema.INNODB_TRX;
在这里插入图片描述
在这里插入图片描述

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

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

代码语言:javascript
复制
kill 1089;

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

在这里插入图片描述
在这里插入图片描述

相关命令:

代码语言:javascript
复制
-- 查看正在锁的事务
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS; 

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

扩展

oracle的操作方式:

  1. 查询锁定记录
代码语言:javascript
复制
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. 删除锁定记录
代码语言:javascript
复制
ALTER system KILL session 'SID,serial#';   

呜啦啦啦啦 看官喜欢的话点赞收藏或者关注一下吧

本文参与?腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-03-10,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客?前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与?腾讯云自媒体分享计划? ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 问题分析
  • 解决办法
  • 过程复现和解决
  • 扩展
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
http://www.vxiaotou.com