MySQL有哪些锁?

1.MySQL有哪些锁?

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

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

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

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

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

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

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

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

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

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

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

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

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

相关推荐
数据库生产实战13 小时前
Oracle 19C RAC下TRUNCATE TABLE的REUSE STORAGE选项作用和风险浅析!
数据库·oracle
小白银子14 小时前
零基础从头教学Linux(Day 60)
linux·数据库·mysql·oracle
瀚高PG实验室14 小时前
数据库安全配置指导
服务器·数据库·瀚高数据库
憋问我,我也不会14 小时前
MYSQL 命令
数据库·mysql
24K老游15 小时前
postgres15 flink cdc同步测试
数据库
无泡汽水15 小时前
MySQL入门练习50题
数据库·mysql
JIngJaneIL16 小时前
助农惠农服务平台|助农服务系统|基于SprinBoot+vue的助农服务系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·毕设·助农惠农服务平台
云外天ノ☼16 小时前
待办事项全栈实现:Vue3 + Node.js (Koa) + MySQL深度整合,构建生产级任务管理系统的技术实践
前端·数据库·vue.js·mysql·vue3·koa·jwt认证
小光学长17 小时前
基于Vue的智慧楼宇报修平台设计与实现066z15wb(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
CodeBlossom17 小时前
Spring Cache快速入门
java·数据库·spring