mysql 锁机制 行 字段_MySql锁机制

锁跟事务有关

一、共享锁(读锁/S锁)

1. 多个事务的查询语句,对同一数据,可以共享一把锁,都能访问到最新数据

2. 如果只有一个事务获取到了一个共享锁,可以更新、删除

3. 如果多个事务都获取到了同一个共享锁,多个事务都不可以更新、删除

4. 使用场景:多个事务都可以获取最新数据

二、排它锁(写锁/X锁)

1. 不能与其他锁共存,只有一个事务能拿到锁

2. 锁释放后,其他事务才能获取

3. 使用场景:一个事务进行查询、更新、删除操作

三、自增锁

1. 如果表中存在自增字段,MySql会自动维护一个自增锁

2. 当事务插入一条数据,自增+1,事务未提交时,查不到这条数据,提交后才能查到

记录锁、间隙锁、临键锁都是排它锁

四、记录锁(行锁)

1. 锁住一行记录

2. 阻止该行被其他事务操作(删除、更新、插入同样的ID)

五、间隙锁

1. 封锁

a. 索引记录中的间隔,例如(1,3], (3,5]等

b. 第一条索引之前的范围,即(-infinity,1]

c. 最后一条索引之后的范围,即(5,infinity]

2. 产生间隙锁的条件

a. 使用普通索引锁定

b. 使用多列唯一索引

c. 使用唯一索引锁定多行记录

3. 只有在事务隔离级别为RR时,才会产生

4. 唯一索引:锁住多条记录,或者不存在的记录时,才会产生间隙锁

5. 普通索引:锁住单条、多条记录,都会产生间隙锁

6. 锁住该条记录相邻的两个键之间的空白区域,防止其他事务在这个范围内插入、修改、删除

7. 防止出现幻读

8. 如果事务隔离级别是RC,间隙锁将会失效

六、临键锁

记录锁和间隙锁的组合,既包含索引记录,又包含索引区间

参考:

标签:事务,删除,记录,间隙,锁住,索引,MySql,机制

来源: https://www.cnblogs.com/june0816/p/6803733.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值