MySQL有哪些锁?

1.MySQL有哪些锁?

  • 全局锁
  • 表级锁
    • 表锁
    • 元数据锁
    • 意向锁
  • 行级锁
    • 记录锁
    • 间隙锁
    • 临键锁
    • 临时意向锁

我了解的是MySQL的锁可以分为全局锁、表级锁、行级锁。

我比较熟悉的是表级锁和行级锁,如果我们对表结构进行修改时,MySQL就会对这个表结构加一个元数据锁。

行级锁目前只有InnoDB存储引擎实现了,主要有记录锁、间隙锁、临键锁、插入意向锁。

2.MySQL是怎么加锁的【可重复读隔离级别】?

加锁的对象是索引,加锁的基本单位是临键锁,临键锁是前开后闭区间,间隙锁是前开后开区间。但是在某些场景下,临键锁是会退化成记录锁或间隙锁的,那就是在使用记录锁或间隙锁就能避免幻读的场景下。

推荐文章:MySQL 是怎么加锁的?

2.1 对于等值查询那么他会怎么加锁?

首先我们可以想到,查询的这个是唯一索引呢,还是非唯一索引,或者说没有索引。

在可重复读隔离级别下,以上三种情况都是有可能的。

如果是唯一索引,还要看查看的记录是否存在,如果存在,那么这条记录加的锁变成记录锁,其它还是临键锁;如果不存在则加间隙锁。

如果是非唯一索引,也要看记录是否存在,如果存在,由于非唯一索引可能有多个相同的值,所以它会进行一个扫描,对于符合条件的二级索引记录加临键锁,最后扫描到第一个不符合条件的二级索引记录就停止,然后对第一个不符合条件的记录加间隙锁,同时,在其主键索引上加记录锁。如果不存在,对第一个不符合条件的二级索引记录加间隙锁。

如果没有索引或没有命中,那就全表扫描,都加临键锁。

相关推荐
心之语歌16 分钟前
LiteFlow 流程引擎引入Spring boot项目集成pg数据库
数据库·spring boot·后端
qq_356408661 小时前
clickhouse query_log 常用查询语句
数据库·clickhouse
小屁不止是运维1 小时前
麒麟操作系统服务架构保姆级教程(八)数据库拆分静态业务拆分和负载均衡
运维·服务器·数据库·架构·负载均衡
凡人的AI工具箱1 小时前
每天40分玩转Django:Django即时聊天应用实战
数据库·人工智能·后端·python·django·sqlite
man20171 小时前
【2024最新】基于Python+Mysql+Django+Vue网上商城的设计与实现Lw+PPT
vue.js·mysql·django
BUG研究员_1 小时前
微服务のGeteWay
java·数据库·微服务
ice___Cpu2 小时前
Redis - 8 ( 10000 字 Redis 入门级教程 )
数据库·redis·缓存
Rk..2 小时前
数据库索引相关总结
java·数据库·sql
菠菠萝宝2 小时前
【Go学习】-01-4-项目管理及协程
数据库·学习·golang·操作系统·软件工程·协程·os
数据的世界012 小时前
SQL使用视图
数据库·sql