美文网首页
mysql学习-20180117

mysql学习-20180117

作者: KrisDD | 来源:发表于2018-01-17 11:50 被阅读0次

    [需要更新]

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

    相关文章

      网友评论

          本文标题:mysql学习-20180117

          本文链接:https://www.haomeiwen.com/subject/opbyoxtx.html