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;
没标准答案,如果你有更好的答案,请直接评论。
- 关于TableView中不止一个section的情况下首个cell的y轴不为0的会造成的问题和解决办法
- 集成微信支付详细步骤及说明——解决点击微信支付只有一个确定按钮的情况
- 连接Mysql提示Can’t connect to local MySQL server through socket各种情况以及解决办法
- 01-什么是多线程上下文切换与多线程死锁的解决办法
- 一个罕见的MySQL redo死锁问题排查及解决过程(pt-pmp)
- SQL 一个用户表中有一个积分字段,假如数据库中有100多万个用户,若要在每年第一天凌晨将积分清零,你将考虑什么,你将想什么办法解决?
- mysql 事务未提交导致死锁 Lock wait timeout exceeded; try restarting transaction 解决办法
- MySQL数据表死锁解决办法
- 分享一个MySQL死锁问题解决的方法
- mysql错误提示Illegal mix of collations (gbk_chinese_ci,IMPLICIT) and (utf8_general_ci,COERCIBLE)的一个解决办法
- mysql 事务未提交导致死锁 Lock wait timeout exceeded; try restarting transaction 解决办法
- swift 中定义的方法只有一个参数没有外部参数名的解决办法
- MySQL安装后不能用是什么情况该如何解决
- mysql导入数据时一个insert过大导致Mysql server has gone way,解决办法
- VS2010在同一个解决方案中有多个工程是,点运行会一直运行最开始的工程,有什么办法解决吗?
- eclipse创建Maven项目后Java Resources里只有一个src/main/resources文件夹,缺少src/main/java等文件夹解决办法
- 一个MySQL死锁问题的解决
- sqlserver高并发情况下 select 和update操作造成死锁的解决方法
- win 2008 R2 或以上版本,只有C盘情况下,PHP上传文件,显示不了解决办法
- Sqlserver高并发情况下 select 和update操作造成死锁的解决方法]