MySQL锁

一、全局锁

全局锁:就是让数据库处于只读状态,整个数据库做逻辑备份的时候用

sql 复制代码
//开启全局锁
flush tables with read lock;

//解除全局锁
unlock tables;

二、表级锁

1、表锁

sql 复制代码
//t_grade加读锁(共享锁)
lock tables t_grade read;

//t_grade加写锁(独占锁)
lock tables t_grade write;
sql 复制代码
//释放表锁
unlock tables;

表锁释放有两种防止:1、会话断开,2、unlock tables来释放

2、元数据锁(MDL)

对一张表数据结构变更时,对该表加的是MDL写锁

三、行级锁

1、锁的基本模式

共享锁S锁:该锁是共享读锁,可以允许多个事务读。通过select ... lock in share mode可以给MySQL加行级读锁。释放锁等事务结束自动释放(提交或回滚)。

排它锁X锁:该锁是排它锁写锁,只允许一个事务来写,其它事务不能读和写。通过SQL语句后加for update可以给MySQL加行级写锁。释放锁等事务结束自动释放(提交或回滚)。

意向锁:该锁是数据库自己维护的。当我们给一行数据加共享锁S锁和排它锁X锁之前,数据库都会加一个意向共享锁和意向排它锁。

2、锁的算法

1、记录锁:当我们对唯一性索引(包括唯一索引和主键索引)进行等值查询时,精准匹配到一行记录的时候,就是记录锁。

2、间隙锁:当我们查询的记录不存在,无论是等值查询还是范围查询,它使用的都是间隙锁。

3、临键锁:当我们使用了范围查询,不仅命中了Record记录,还包含了Gap间隙,在这种情况下我们就使用了临键锁。它是MySQL默认的行锁算法,相当于记录锁+间隙锁。

相关推荐
聆风吟º1 小时前
Oracle到KingbaseES数据库迁移:全流程实战指南与避坑总结
数据库·oracle·数据库迁移·kingbasees
哈__1 小时前
Oracle至KingbaseES数据库迁移全攻略:痛点拆解、配置实操与问题排查
数据库·oracle
JZC_xiaozhong2 小时前
电商ERP如何同步订单数据到MySQL?集成方案解析
数据库·mysql·数据分析·etl工程师·嵌入式实时数据库·电商erp集成·数据集成与应用集成
消失的旧时光-19432 小时前
第四篇(实战): 订单表索引设计实战:从慢 SQL 到毫秒级
java·数据库·sql
知识分享小能手2 小时前
Oracle 19c入门学习教程,从入门到精通, Oracle 表空间与数据文件管理详解(9)
数据库·学习·oracle
zhengfei6113 小时前
Chroma DB — 未经授权的信息披露
数据库
KaiwuDB3 小时前
KaiwuDB 获评“2025 中国大数据产业年度国产化优秀代表厂商”
数据库
百***07454 小时前
一步API+Gemini 3.0 Pro进阶实战:多模态开发、性能调优与项目落地
数据库·microsoft
不想写bug呀4 小时前
Redis主从复制介绍
数据库·redis
颜颜yan_4 小时前
Oracle 迁移到 KingbaseES 实战:从评估到追平的一套可落地流程
数据库·oracle