mysql学习-20180117

2018-01-17  本文已影响0人  KrisDD

[需要更新]

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加锁有次序

上一篇下一篇

猜你喜欢

热点阅读