2020-07-08:mysql只有一个表a,什么情况下会造成死锁,解决办法是什么?

网友投稿 722 2022-05-29

2020-07-08:mysql只有一个表a,什么情况下会造成死锁,解决办法是什么?

福哥答案2020-07-08:

表锁是不会出现死锁的,但锁等待现象是有可能的。

行锁是行级别的,有可能出现死锁。环形等待死锁和唯一键死锁 很常见。

避免死锁方法:

1.减少事务操作的记录数。

2.约定按相同顺序访问记录。

3.对事务中要操作的记录进行排序。

4.避免使用唯一键约束。

5.用表锁,不用行锁。

6.在事务中,如果要更新记录,应该直接申请足够级别的锁,即排他锁,而不应先申请共享锁,更新时再申请排他锁,因为当用户申请排他锁时,其他事务可能又已经获得了相同记录的共享锁,从而造成锁冲突,甚至死锁。

解除正在死锁的状态有两种方法:

第一种杀死会话:

1.查询是否锁表

show OPEN TABLES where In_use > 0;

2.查询进程(如果您有SUPER权限,您可以看到所有线程。否则,您只能看到您自己的线程)

show processlist

或者查询出所有需要Killd的Id;

select concat('KILL ',id,';') from information_schema.processlist where user='root';

3.杀死进程id(就是上面命令的id列)

kill id

第二种杀死事务:

1.查看下在锁的事务

SELECT * FROM INFORMATION_SCHEMA.INNODB_TRX;

2.杀死进程id(就是上面命令的trx_Mysql_thread_id列)

kill 线程ID

例子:

查出死锁进程:SHOW PROCESSLIST

杀掉进程 KILL 420821;

其它关于查看死锁的命令:

1:查看当前的事务

SELECT * FROM INFORMATION_SCHEMA.INNODB_TRX;

2:查看当前锁定的事务

SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;

3:查看当前等锁的事务

SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS;

没标准答案,如果你有更好的答案,请直接评论。

任务调度 MySQL

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Selenium 如何处理多层嵌套 iframe
下一篇:如何请求一个需要登陆才能访问的接口(基于cookie)—apipost
相关文章