当前位置: 首页 > ai >正文

关于脏读,幻读,可重复读的学习

  1. mysql 可以查询当前事务隔离级别

默认是RR
repeatable-read

  1. 如果要测脏读 要配成未提交读 RU

读到了未提交的数据。

3.演示不可重复读
要改成提交读 RC

这个是指事务还未结束,其他事务修改了值。导致我两次读的不一样。

4.RR–可以解决不可重复读

小总结:
RU-》有脏读-》为了解决脏读来一个RC,读已提交-》有不可重复读的问题-》为了解决不可重复读的问题来一个RR。-》有幻读-》

5.在RR隔离级别下,快照读的数据范围是:
✅ ​事务首次SELECT时已提交的数据​ + ​当前事务自身的修改

6.当前读 vs 快照读​
​快照读​(普通SELECT)→ 依赖Read View,​不包含未提交数据​

​当前读​(SELECT FOR UPDATE)→ 读取最新数据(含未提交),通过锁机制实现

7.​事务开始 ≠ 快照生成​
RR下快照在第一个SELECT时生成,而非BEGIN执行时
。例如:
sql
复制
BEGIN; – 事务开始,但未生成Read View
SELECT …; – 生成Read View并记录快照

8.innodb 的MVCC+间隙锁,让RR级别就解决了幻读。

9.MVCC

mutiversion concurrency control
多版本并发控制器

事务隔离级别的无锁的实现方式,提高事务的并发性能。

是事务隔离级别的一种底层实现方式。

并不是所有的隔离级别都用到MVCC。

4级别

读未提交–>脏读
读已提交—>不可重复读
可重复读----》幻读
串行化 Serializable S SER 锁表。

然后幻读–》事务1对整个表进行汇总
如对某字段求和。 但是另外一个事务插入了一条数据。

幻读与不可重复读看起来像,但是幻读往往针对整张表,而不可重复读是针对某一条或者几条数据。

MVCC–3个隐藏列
1.事务ID
2.DB_ROLL_PTR
如果回滚可以链到之前的数据。
3.无主键时有一个row id。这个不重要

历史数据存储于 undo log。

若读已提交,从undo log中找历史数据。

若RC。每次查询,创建一个ReadView

定位到undolog。。。

当前事务 正在并发的事务 未开始的

进行中的事务—》还未提交的有个最小的
最大的 可能还未开始。

自己写的可以。
快照之前已提交的可以。

如果是快照瞬间,活跃事务做的。
读已提交是不行的。

最小最大中—只有它自己的OK。

小于最小的 一直OK

大于最大的 一直不OK.

徐庶讲的是读已提交下的MVCC。

另外的也讲了:
读未提交,不需加锁,也不需MVCC

串行化—表锁 无需MVCC

可重复读—》只有在第一次查询建快照。

所以RC RR MVCC机制大体相似,只是是否每次查询建快照的区别。

简单理解就是一次RC里面做了多次RR。没什么意义的评论。

10.关于徐庶说RR无法解决幻读的争议。
字节面试官说MVCC+间隙锁解决了幻读
刚刚看的视频,UP演示的也是RR能解决幻读。

http://www.xdnf.cn/news/12519.html

相关文章:

  • C++中的排列组合算法详解
  • SUSE Linux 发行版全面解析:从开源先驱到企业级支柱
  • element树结构el-tree,默认选中当前setCurrentKey无效
  • golang项目中如何使用私密仓库的扩展包
  • 1.4 Node.js 的 TCP 和 UDP
  • 基于 STM32 的四路 PWM 控制智能小车运动的模块化控制程序
  • PDF图片和表格等信息提取开源项目
  • FastAPI安全机制:从OAuth2到JWT的魔法通关秘籍
  • Web前端基础:JavaScript
  • C++字符串解析2
  • yolov11与双目测距结合,实现目标的识别和定位测距(onnx版本)
  • Docker、Wsl 打包迁移环境
  • |从零开始的Pyside2界面编程| 用Pyside2打造一个AI助手界面
  • pycharm 中文字体报错
  • 从零开始搭建 Pytest 测试框架(Python 3.8 + PyCharm 版)
  • Android Studio 解决首次安装时下载 Gradle 慢问题
  • spring中的@RabbitListener注解详解
  • C++设计模式 - 单例模式
  • Python Copilot【代码辅助工具】 简介
  • AI数据分析在体育中的应用:技术与实践
  • 初识结构体,整型提升及操作符的属性
  • 12.6Swing控件4 JSplitPane JTabbedPane
  • 第六章 进阶18 小杨的困惑
  • 博弈论概述
  • 网络库libhv介绍
  • Selenium自动化测试之弹窗处理
  • [Python学习日记-91] 并发编程之多线程 —— threading 模块、开启线程的方式、线程相关的其他方法
  • 腾讯加持,销售易 CRM 优势几何?
  • 本机无法远程别的计算机的方法
  • 自制喜悦字贴