您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

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

2024/3/12 10:57:38发布25次查看
问题分析一般都是数据库事务未提交,导致update或者delete卡死。
解决办法在执行完更新或删除后,记得将事务提交commit;
找到数据库客户端,执行commit操作。
如果还不行。当数据库在执行数据操作失败或事务未提交时,它会锁定需要执行的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#';
以上就是mysql数据库执行update卡死问题怎么解决的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product