概述
介绍
在并发访问时,解决数据访问的一致性、有效性问题
分类
MySQL中的锁,按照锁的粒度分,分为以下三类:
- 全局锁:锁定数据库中的所有表
- 表级锁:每次操作锁住整张表
- 行级锁:每次操作锁住对应的行数据
全局锁
介绍
性能较差,数据逻辑备份时使用
演示
特点
表级锁
介绍
表级锁,每次操作锁住整张表,锁定粒度大,发生锁冲突的概率最高,并发度最低,应用在MyISAM、InnoDB、BDB等存储引擎中
分类
对于表级锁,主要分为以下三类:
- 表锁
- 元数据锁(meta data lock,MDL)
- 意向锁
表锁
读锁不会阻塞其他客户端的读,但是会阻塞写。写锁即会阻塞其他客户端的读,又会阻塞其他客户端的写
元数据锁
意向锁
为了避免DML在执行时,加的行锁与表锁的冲突,在InnoDB中引入了意向锁,使得表锁不用检查每行数据是否加锁,使用意向锁来减少表锁的检查
意向锁与表锁的兼容情况