数据库死锁问题,Navicat修改表的时候,数据库中的一张表打不开也关不上
问题描述
在修改一张数据库的表的时候,加了一个字段。然后鼠标指针就一直在转圈,Navicat就未响应。
解决方法
一般表打不开有三种原因:
原因一:
表死锁,会出现这样的情况,锁不释放,无论多久都读取不了数据,一直加载中!
原因二:
表里面的数据量太大造成的。
原因三:
网络慢,卡,数据不能传输
下面介绍一下死锁:
一、 什么是死锁
死锁是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去.此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等的进程称为死锁进程.
二、 死锁产生的四个必要条件
•互斥条件:指进程对所分配到的资源进行排它性使用,即在一段时间内某资源只由一个进程占用。如果此时还有其它进程请求资源,则请求者只能等待,直至占有资源的进程用毕释放
•请求和保持条件:指进程已经保持至少一个资源,但又提出了新的资源请求,而该资源已被其它进程占有,此时请求进程阻塞,但又对自己已获得的其它资源保持不放
•不剥夺条件:指进程已获得的资源,在未使用完之前,不能被剥夺,只能在使用完时由自己释放
•环路等待条件:指在发生死锁时,必然存在一个进程——资源的环形链,即进程集合{P0,P1,P2,···,Pn}中的P0正在等待一个P1占用的资源;P1正在等待P2占用的资源,……,Pn正在等待已被P0占用的资源
这四个条件是死锁的必要条件,只要系统发生死锁,这些条件必然成立,而只要上述条件之一不满足,就不会发生死锁。
解决方法:
在navicat里右击数据库名称打开mysql的命令行,然后输入:
SHOW PROCESSLIST;
出现如下图,如果status列有lock字眼,那么通过Info状态就可以得出哪张表被锁了:
如果有被锁的表,那么在命令行输入(kill 后面的id是上图的第一列值):
KILL 10866;//后面的数字即时进程的ID
把status带lock字眼的即时进程都删掉,表就可以打开了。
上一篇: MySQL死锁case分析