当前位置 : 主页 > 编程语言 > java >

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

来源:互联网 收集:自由互联 发布时间:2022-06-30
@toc执行数据库更新update操作的时候数据库卡死了 问题分析 一般都是数据库事务未提交,导致update或者delete卡死。 解决办法 在执行完更新或删除后,记得将事务提交commit; 找到数据库客

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

问题分析

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

解决办法

  • 在执行完更新或删除后,记得将事务提交commit;
  • 找到数据库客户端,执行commit操作。
  • 如果还不行。 那么应该是数据库在执行数据操作失败 or 事务未提交 之后,将需要执行的sql语句锁死了。

    过程复现和解决

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

    show variables like 'autocommit';

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

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

    表中数据如下:image.png打开两个窗口分别执行update操作

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

    查询正在执行的事务:

    SELECT * FROM information_schema.INNODB_TRX;

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

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

    kill 1089;

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

    -- 查看正在锁的事务 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#';

    本文内容到此结束了, 如有收获欢迎点赞

  • 上一篇:Rust FFI 编程 - Rust导出共享库06
    下一篇:没有了
    网友评论