[需要更新]
mysql学习
mysql 5.6 官方版本说加索引时,不会锁表,但是表加索引时,依然会存在2种情况会对锁表!
第一:如果有慢查询时
第二:如果有事物未提交时,但已经锁表了
所以需要先手动排查下,是否有以上2种情况,在加索引,如果在加表过程中出现问题立即中断;
排查命令:
查询最近死锁日志
show engine innodb status;
查询正在运行线程
show processlist;
查看是否有慢查询
show variables like 'slow_query%';
查看表的建表语句
show create table 表名;
查看表的索引:
show INDEX from `库`.`表名`;
然后根据以上的了解下
MySQL有三种锁的级别:页级、表级、行级。
表级锁:开销小,加锁快;不会出现死锁;锁定粒度大,发生锁冲突的概率最高,并发度最低。
行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高。
页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般
什么情况下会造成死锁
所谓死锁: 是指两个或两个以上的进程在执行过程中,
因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去.
此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程称为死锁进程.
表级锁不会产生死锁.所以解决死锁主要还是针对于最常用的InnoDB.
死锁的关键在于:两个(或以上)的Session加锁的顺序不一致。
那么对应的解决死锁问题的关键就是:让不同的session加锁有次序