当前位置:网站首页>不同的操作加不同的锁详解
不同的操作加不同的锁详解
2022-08-01 19:57:00 【努力学习的狗】
- 事务利用MVCC进行的读取操作称为一致性读(或者快照读)。所有普通的SELECT语句在RC(读已提交),RR(可重复读)隔离级别下都算是快照读,一致性读不会对表中的任何记录进行加锁操作,其他事务可以自由地对表中的记录进行改动
select * from table_name
select * from table_name t1 Inner Join table_name_name t2 on t2.id = t1.id- 共享锁的锁定读,如果当前事务执行了锁定读,那么就会加上S锁(共享),其它事务可以继续获得这些记录的S锁,但是不能获取到这些记录的X锁,也不能直接改动这些记录。如果其它事务想要获取到对应的X锁,那么就会被阻塞,等到当前事务的S锁释放
select * from table_name LOCK IN SHARE MODE- 独占锁的锁定读,如果执行了该语句,那么会就给记录加上X锁,其它事务不可以获得这些记录的S锁,也不能获取到这些记录的X锁,不允许直接改动这些记录。如果其它事务想要获取到对应的X锁或者,那么就会被阻塞,等到当前事务提交后将对应的记录X锁释放为止。
SELECT * FROM UPDATE - DELETE操作:对一条记录执行DELETE操作的过程其实是先在B+树中定位到这条记录的位置,然后获取到这条记录的X锁,然后执行DELETE Mark操作(可以简单理解为获取X锁的锁定读)
- UPDATE操作: 在对一条记录进行UPDATE操作时分为3中情况
- 如果未修改该记录的键值并且被更新的列所占用的存储空间在修改前后未发生变化,则先在B+树中定位到这条记录的位置,然后再获取记录的X锁,最后在原记录的位置进行修改操作。(先定位待修改记录在B+树中的位置,然后再获取记录的X锁的过程,可以看成是一个获取X锁的锁定读)
- 如果未修改该记录的键值并且至少有一个被更新的列占用的存储空间在修改前后发生变化,则先在B+树中定位到这条记录的位置,然后获取记录的X锁,之后将该记录彻底删除掉(把记录彻底移入垃圾链表),最后再插入一条新记录。(先定位到待修改记录再B+树中的位置 ,然后再获取记录的X锁的过程。可以看成一个获取X锁的锁定读,与被彻底删除的记录的关联记录的锁也会被转移到这条新插入的记录上来)
- 如果修改了该记录的键值,则相当于在原记录上执行DELETE操作之后再来一次INSERT操作,加锁操作就需要按照DELETE和INSETR的规则进行
- INSERT操作: 一般情况下,新插入的一条记录受隐式锁保护,不需要再内存中为其生成对应的锁结构。
边栏推荐
猜你喜欢

Creo5.0草绘如何绘制正六边形

Database Plus 的云上之旅:SphereEx 正式开源 ShardingSphere on Cloud 解决方案

面试突击70:什么是粘包和半包?怎么解决?

密码学的基础:X.690和对应的BER CER DER编码

【kali-信息收集】(1.5)系统指纹识别:Nmap、p0f

小数据如何学习?吉大最新《小数据学习》综述,26页pdf涵盖269页文献阐述小数据学习理论、方法与应用

正则表达式

How to install voice pack in Win11?Win11 Voice Pack Installation Tutorial

【kali-信息收集】(1.6)服务的指纹识别:Nmap、Amap

八百客、销售易、纷享销客各行其道
随机推荐
第60章 ApplicationPart自动集成整体性和独立性插件项
kingbaseV8R3和postgreSQL哪个版本最接近?
From ordinary advanced to excellent test/development programmer, all the way through
把 Oracle 数据库从 RAC 集群迁移到单机环境
分享一个适用于MCU项目的代码框架
58:第五章:开发admin管理服务:11:开发【管理员人脸登录,接口】;(未实测)(使用了阿里AI人脸识别)(演示了,使用RestTemplate实现接口调用接口;)
使用Huggingface在矩池云快速加载预训练模型和数据集
MySQL开发技巧——存储过程
Pytorch模型训练实用教程学习笔记:四、优化器与学习率调整
An implementation of an ordered doubly linked list.
Database Plus 的云上之旅:SphereEx 正式开源 ShardingSphere on Cloud 解决方案
我的驾照考试笔记(2)
第57章 业务逻辑之业务实体与数据库表的映射规则定义
openresty 动态黑白名单
【软考软件评测师】基于规则说明的测试技术下篇
短视频软件开发,Android开发,使用Kotlin实现WebView
18、分布式配置中心nacos
洛谷 P2440 木材加工
1个小时!从零制作一个! AI图片识别WEB应用!
通配符 SSL/TLS 证书