innoDB八种锁

文章详细阐述了行锁的两种类型——共享锁和排它锁,以及意向锁的作用,它们在InnoDB中用于支持更细粒度的锁并提高加锁效率。当没有索引时,全表扫描可能导致锁表。通过唯一索引加锁会同时锁定主键索引,因为检索数据时会通过主键找到对应行。文章还提到了锁的算法,特别是主键索引在不同情况下的锁定范围。
摘要由CSDN通过智能技术生成

行锁的原理

四种基本锁

共享锁

所有可读不可写,只有当前可读可写

排它锁

所有不可读不可写,只有当前可读可写

共享锁和排它锁都是行锁

意向锁

如果一张表上面至少有一个意向共享锁,说明有其他的事务给其中的某些数据行加上了共享锁。
如果一张表上面至少有一个意向排他锁,说明有其他的事务给其中的某些数据行加上了排他锁。
表级别的锁:意向共享锁、意向排他锁

那么这两个表级别的锁存在的意义是什么呢?第一个,我们有了表级别的锁,在InnoDB 里面就可以支持更多粒度的锁。它的第二个作用,我们想一下,如果说没有意向锁的话,当我们准备给一张表加上表锁的时候,我们首先要做什么?是不是必须先要去判断有没其他的事务锁定了其中了某些行?如果有的话,肯定不能加上表锁。那么这个时候我们就要去扫描整张表才能确定能不能成功加上一个表锁,如果数据量特别大,比如有上千万的数据的时候,加表锁的效率是不是很低?
但是我们引入了意向锁之后就不一样了。
我只要判断这张表上面有没有意向锁,如果有,就直接返回失败。如果没有,就可以加锁成功。
所以 InnoDB 里面的表锁,我们可以把它理解成一个标志。就像火车上厕所有没有人使用的灯,是用来提高加锁的效率的

锁是用来解决事务对数据的并发访问的问题的。
1、为什么表里面没有索引的时候,锁住一行数据会导致锁表?
或者说,如果锁住的是索引,一张表没有索引怎么办?
所以,一张表有没有可能没有索引?

  • 如果我们定义了主键(PRIMARY KEY),那么 InnoDB 会选择主键作为聚集索引。
  • 如果没有显式定义主键,则 InnoDB 会选择第一个不包含有 NULL 值的唯一索引作为主键索引。
  • 如果也没有这样的唯一索引,则 InnoDB 会选择内置 6 字节长的 ROWID 作为隐藏的聚集索引,它会随着行记录的写入而主键递增。

所以,为什么锁表,是因为查询没有使用索引,会进行全表扫描,然后把每一个隐藏的聚集索引都锁住了。

2、为什么通过唯一索引给数据行加锁,主键索引也会被锁住?
大家还记得在 InnoDB 里面,当我们使用辅助索引的时候,它是怎么检索数据的吗?辅助索引的叶子节点存储的是什么内容?
在辅助索引里面,索引存储的是二级索引和主键的值。比如name=4,存储的是name的索引和主键 id 的值 4。而主键索引里面除了索引之外,还存储了完整的数据。所以我们通过辅助索引锁定一行数据的时候,它跟我们检索数据的步骤是一样的,会通过主键值找到主键索引,然后也锁定。
在这里插入图片描述
现在我们已经搞清楚 4 个锁的基本类型和锁的原理了,在官网上,还有 3 种锁,我们把它理解为锁的算法。我们也来看下 InnoDB 在什么时候分别锁住什么范围。

锁的算法

在这里插入图片描述
主键索引,它是整型的,可以排序,所以才有这种区间。如果我的主键索引不是整形,是字符怎么办呢?字符可以排序吗? 用 ASCII 码来排序。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyISAM和InnoDB是MySQL中常用的两种存储引擎,它们在功能和性能上有一些区别。 1. 事务支持InnoDB支持事务处理,而MyISAM不支持。事务是一组操作的原子单位,可以保证数据的一致性和完整性。如果你需要使用事务来控制并发访问或者实现数据回滚等功能,那么InnoDB是更好的选择。 2. 级别:MyISAM使用表级定,而InnoDB支持行级定。表级定意味着当一个线程对表进行修改时,其他线程无法对同一表进行修改。而行级定允许多个线程同时修改表中的不同行,提高了并发性能。 3. 外键支持InnoDB支持外键约束,而MyISAM不支持。外键是用来定义表与表之间的关系的约束条件,可以保证数据的一致性和完整性。如果你需要在数据库层面实现数据完整性的控制和关联查询等功能,那么InnoDB是更好的选择。 4. 崩溃恢复:InnoDB具有崩溃恢复的能力,可以在数据库发生故障或者断电等情况下恢复数据的一致性。而MyISAM不具备这种能力,可能会导致数据丢失或者损坏。 5. 全文索引:MyISAM支持全文索引,而InnoDB在MySQL 5.6版本之前不支持全文索引。全文索引可以提高对文本内容的搜索效率。 综上所述,如果你需要事务支持、并发性能较高、数据完整性控制和崩溃恢复等特性,那么InnoDB是更好的选择。如果你主要进行读操作,并且对于事务和数据完整性要求不高,那么MyISAM可能是一个更简单和高效的选项。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值