当前位置: 首页 > news >正文

MySQL中的行级锁

MySQL中锁有很多种,其中从锁的粒度来区分的话可以分为表级锁,行级锁,页级锁

本文主要介绍下

行级锁

MySQL中的行级锁是MySQL中InnoDB存储引擎提供的一种细粒度的锁,基于索引实现的,锁是加在索引上的,而不是数据行本身。

同样是行级锁,InnoDB存储引擎对于其实现还可以细分为记录锁(Record Lock),间隙锁(Gap Lock),临键锁(Next-Key Lock)和插入意向锁(Insert Intention Lock)

记录锁(Record Lock)

记录锁也就是常说的行锁,顾名思义其锁定的是某一行数据。

-- id = 1 的行会被加记录排他锁
update product_sale_record set sold_num = sold_num + 1 where id = 1;-- id = 1 的行会被加共享锁
select * from product_sale_record  where id = 1; LOCK IN SHARE MODE;
场景举例

假设两个事务A,B并发执行下面的SQL:

start transaction;update t_shop_product_sale_record set sold_num = sold_num +1 where id = 1;commit;

当事务A执行 update 时会对 id = 1 这行数据的排它锁。

在事务A未提交的情况下,如果开启事务B执行 update ,会出现锁等待然后超时:Lock wait timeout exceeded; try restarting transaction

间隙锁(Gap Lock)

锁定索引记录之间的间隙,防止其他事务在范围内插入新数据。

-- id 在 1 和 10 之间的间隙会被加排他锁。
update product_sale_record WHERE id > 1 AND id < 10;-- id 在 1 和 10 之间的间隙会被加共享锁。
select * from product_sale_record  WHERE id > 1 AND id < 10 LOCK IN SHARE MODE;

临键锁(Next-Key Lock)

临键锁可以理解为是记录锁和间隙锁的组合,锁定索引记录及其前面的间隙。

-- id > 1 的记录及其前面的间隙会被加排他锁
update product_sale_record WHERE id > 1;-- id > 1 的记录及其前面的间隙会被加共享锁
select * from product_sale_record where id > 1 LOCK IN SHARE MODE;

http://www.mrgr.cn/news/93051.html

相关文章:

  • LINUX网络基础 - 网络编程套接字,UDP与TCP
  • 【实战 ES】实战 Elasticsearch:快速上手与深度实践-2.2.2线程池配置与写入限流
  • vocal~怎么没人告诉我?大数据技术组件(更新中......)
  • Vue 3 中 unref 的作用与 Vue Router currentRoute 的知识
  • 物理竞赛中的线性代数
  • 服务器时间同步
  • PAT乙级真题 / 知识点(1)
  • Metal学习笔记七:片元函数
  • C++学习之C++初识、C++对C语言增强、对C语言扩展
  • 静态时序分析:SDC约束命令set_clock_jitter详解
  • 【实战 ES】实战 Elasticsearch:快速上手与深度实践-2.2.3案例:电商订单日志每秒10万条写入优化
  • vue videojs使用canvas截取视频画面
  • 基于 DataEase 的企业数据分析实践
  • 硅基流动nodejs流式输出
  • 使用vite创建vue3项目
  • T-SQL 语言基础: SQL 数据库对象元数据及配置信息获取
  • AMD RDNA3 GPU架构解析
  • (十 九)趣学设计模式 之 中介者模式!
  • 【算法】手撕二分查找
  • stm32 jlink烧录时写保护