欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

数据库死锁问题,Navicat修改表的时候,数据库中的一张表打不开也关不上

程序员文章站 2022-05-22 11:20:33
...

问题描述

在修改一张数据库的表的时候,加了一个字段。然后鼠标指针就一直在转圈,Navicat就未响应。

解决方法

一般表打不开有三种原因:
原因一:
表死锁,会出现这样的情况,锁不释放,无论多久都读取不了数据,一直加载中!

原因二:
表里面的数据量太大造成的。

原因三:
网络慢,卡,数据不能传输

下面介绍一下死锁:

一、 什么是死锁

死锁是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去.此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等的进程称为死锁进程.

二、 死锁产生的四个必要条件

•互斥条件:指进程对所分配到的资源进行排它性使用,即在一段时间内某资源只由一个进程占用。如果此时还有其它进程请求资源,则请求者只能等待,直至占有资源的进程用毕释放

•请求和保持条件:指进程已经保持至少一个资源,但又提出了新的资源请求,而该资源已被其它进程占有,此时请求进程阻塞,但又对自己已获得的其它资源保持不放

•不剥夺条件:指进程已获得的资源,在未使用完之前,不能被剥夺,只能在使用完时由自己释放

•环路等待条件:指在发生死锁时,必然存在一个进程——资源的环形链,即进程集合{P0,P1,P2,···,Pn}中的P0正在等待一个P1占用的资源;P1正在等待P2占用的资源,……,Pn正在等待已被P0占用的资源

这四个条件是死锁的必要条件,只要系统发生死锁,这些条件必然成立,而只要上述条件之一不满足,就不会发生死锁。

解决方法:
在navicat里右击数据库名称打开mysql的命令行,然后输入:

SHOW PROCESSLIST;

出现如下图,如果status列有lock字眼,那么通过Info状态就可以得出哪张表被锁了:

数据库死锁问题,Navicat修改表的时候,数据库中的一张表打不开也关不上

如果有被锁的表,那么在命令行输入(kill 后面的id是上图的第一列值):

KILL 10866;//后面的数字即时进程的ID
把status带lock字眼的即时进程都删掉,表就可以打开了。

相关标签: mysql 死锁