MySQL中的行级锁详解

 更新时间:2025年03月03日 09:38:25   作者:WannaRunning  
MySQL中的行级锁是InnoDB存储引擎提供的一种细粒度锁,基于索引实现,MySQL中锁有很多种,其中从锁的粒度来区分的话可以分为表级锁,行级锁,页级锁,本文主要介绍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;

到此这篇关于MySQL中的行级锁的文章就介绍到这了,更多相关mysql行级锁内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL索引下推的深入探索

    MySQL索引下推的深入探索

    这篇文章主要介绍了MySQL的索引下推,索引下推是为了解决在过滤条件时,可能导致大量的数据行被检索出来,但实际上只有很少的行满足WHERE子句中的所有条件的情况,需要的朋友可以参考下
    2022-07-07
  • mysql use命令选择数据库详解

    mysql use命令选择数据库详解

    这篇文章主要介绍了mysql 使用use命令选择数据库的相关资料,需要的朋友可以参考下
    2016-09-09
  • MySQL如何修改字段类型和字段长度

    MySQL如何修改字段类型和字段长度

    这篇文章主要介绍了MySQL如何修改字段类型和字段长度,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-06-06
  • 数据库sql语句优化

    数据库sql语句优化

    今天小编就为大家分享一篇关于数据库sql语句优化,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • 解析MySQL join查询的原理

    解析MySQL join查询的原理

    这篇文章主要介绍了MySQL join查询的原理,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-01-01
  • mysql中general_log日志知识点介绍

    mysql中general_log日志知识点介绍

    这篇文章主要介绍了mysql中general_log日志知识点的介绍以及其他相关内容,以后兴趣的朋友们学习下。
    2019-08-08
  • CenOS6.7下mysql 8.0.22 安装配置方法图文教程

    CenOS6.7下mysql 8.0.22 安装配置方法图文教程

    这篇文章主要为大家详细介绍了CenOS6.7下mysql 8.0.22 安装配置方法图文教程,文中安装步骤介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-11-11
  • MySQL中TINYINT、INT 和 BIGINT的具体使用

    MySQL中TINYINT、INT 和 BIGINT的具体使用

    MySQL提供了多种整数类型来满足不同的数据存储需求,本文主要介绍了MySQL中TINYINT、INT 和 BIGINT的具体使用,具有一定的参考价值,感兴趣的可以了解一下
    2024-07-07
  • MySQL在不知道列名情况下的注入详解

    MySQL在不知道列名情况下的注入详解

    这篇文章主要给大家介绍了关于MySQL在不知道列名情况下的注入的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用mysql具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-03-03
  • MySQL表分区的几种实现

    MySQL表分区的几种实现

    本文主要介绍了MySQL表分区的几种实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08

最新评论