07: mysql锁

Posted 不做大哥好多年

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了07: mysql锁相关的知识,希望对你有一定的参考价值。

1.1 mysql中锁概念

  1、MyISAM和InnoDB支持的锁类型

      1. 相对其他数据库而言,MySQL的锁机制比较简单,其最显著的特点是不同的存储引擎支持不同的锁机制。

      2. MyISAM和MEMORY存储引擎采用的是表级锁(table-level locking)。

      3. InnoDB存储引擎既支持行级锁(row-level locking),也支持表级锁,但默认情况下是采用行级锁。

  2、MySQL这3种锁的特性

      1. 表级锁:开销小,加锁快;不会出现死锁;锁定粒度大,发生锁冲突的概率最高,并发度最低。

      2. 行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高。

      3. 页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般。

      表级锁更适合于以查询为主,只有少量按索引条件更新数据的应用,如Web应用;
      而行级锁则更适合于有大量按索引条件并发更新少量不同数据,同时又有并发查询的应用,如一些在线事务处理(OLTP)系统。

 


以上是关于07: mysql锁的主要内容,如果未能解决你的问题,请参考以下文章

07 | 行锁功过:怎么减少行锁对性能的影响?

[转帖]深入理解 MySQL—锁事务与并发控制

Mysql加锁过程详解-innodb下的记录锁,间隙锁,next-key锁

Mysql加锁过程详解-innodb下的记录锁,间隙锁,next-key锁

MySQL 进阶 锁 -- MySQL锁概述MySQL锁的分类:全局锁(数据备份)表级锁(表共享读锁表独占写锁元数据锁意向锁)行级锁(行锁间隙锁临键锁)

mysql插入意向锁测试