八股文打卡day34——数据库(11)

面试题:谈一下你对MySQL中锁的了解?

我的回答:

首先,从锁的粒度来分,可以分为:
①全局锁。全局锁主要用于数据库的备份,加上全局锁,意味着整个数据库都处于只读的状态。
②行级锁。行级锁是用来锁定某一行数据记录的锁。
可以分为行级共享锁(读锁)和行级排他锁(写锁)。
当一行记录加了行级共享锁时,其他事务还可以进行读操作。
当一行记录加了行级排他锁时,其他事务既不可以进行读也不可以进行写。

行级锁中还有:
1.间隙锁。间隙锁就是给比如主键id的间隙中加锁,防止插入幻影数据。
2.临键锁。临键锁就是给主键id的间隙以及本身这个id加锁,防止插入幻影数据。

通过这两个锁从而防止幻读问题。
③表级锁。表级锁是用来锁定某一张表数据记录的锁。
表级锁中有意向锁。
为什么会有意向锁的出现呢。
比如我想给一张表加排他锁,我首先需要判断这张表中是否存在行级排他锁,如果存在行级排他锁,就会不兼容。如果这张表很大,有100万条数据,那么我就需要遍历100W条数据,去找是否存在行级排他锁,这样是十分耗时的。
这个时候就诞生了意向锁,可以将意向锁理解为一个标记。如果我在这张表中的某一行加了行级排他锁,那么就会加上对应的意向排他锁,从而标识这张表中存在行级排他锁。同理,如果给一张表中某一行加上了行级共享锁,那么也会给这行记录所属的表加上意向共享锁来进行标识。
这样就极大的提高了效率。

从性质来分的话,可以分为:共享读锁和独占写锁。
①共享读锁。就是给读操作加锁,for share字段。
②独占写锁。就是给写操作加锁,for update字段。

回答时间:2024.03.16

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值