InnoDB锁实现

这篇博客详细介绍了MySQL InnoDB存储引擎的锁机制,包括锁的基本概念、行锁和表锁(意向锁)的类型及差异。重点讨论了行锁的三种形式:共享锁、排它锁以及它们在不同场景下的应用。此外,还深入解析了锁的原理,如为何没有索引时会锁住整张表,以及如何通过主键索引理解行锁的实现。
摘要由CSDN通过智能技术生成

一、锁

1.基本概念

MySQL的锁是为了解决资源竞争的问题,Java 里面的资源是对象,数据库的资源就是数据表或者数据行。所以锁是用来解决事务对数据的并发访问的问题的。

InnoDB锁有两种

  • 表锁(意向锁,Intention Locks)
    • 意向共享锁(Intention Shared Locks)
    • 意向排它锁(Intention Exclusive Locks)
  • 行锁
    • 共享锁(Shared Locks)
    • 排它锁(Exclusive Locks)

行锁的算法:

  • 记录锁
  • 间隙锁
  • 临键锁

表锁与行锁对比:

  • 锁定粒度:表锁 > 行锁

  • 加锁效率:表锁 > 行锁

    因为表锁只管锁住整张表,而行锁还要检索这一行数据再加锁

  • 冲突概率:表锁 > 行锁

    锁住一张表的时候,其他任何一个事务都不能操作这张表。但是

    锁住一行数据的时候,其他的事务还可以来操作其他没有被锁的行

  • 并发性能:表锁 < 行锁

2.行锁

1.共享锁(shared Locks)

简称S锁,也称读锁,多个事务对于同一数据可以共享一把锁,都能访问到数据,但是只能读不能修改。

# 加读锁方式
select .... LOCK IN SHARE MODE;

释放锁方式:事务结束(提交或其他终止事务方式),锁自动释放

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值