看图说话:对脏读、不可重复度、幻读进行总结

news2025/1/24 2:12:31

1、脏读

在这里插入图片描述

  1. 「事务B」将 id 为 1 的用户 name 修改为“小卡”,事务未提交
  2. 「事务A」查询 id 为 1 的用户数据,此时 name 已为“小卡”。

2、不可重复度

在这里插入图片描述

  1. 「事务A」第一次读取 id 为 1 的用户,name 是 “卡卡”。
  2. 「事务B」将 id 为 1 的用户 name 改为了 “小卡”,并提交了事务
  3. 「事务A」第二次读取 id 为 1 的用户,此时 name 就变成 “小卡” 了。

3、幻读

这里「幻读」我分成 2 个场景来总结,一个是INSERT、一个是DELETE,如下:

3.1、INSERT

在这里插入图片描述

  1. 「事务A」第一次读取 age 为 21 的用户,返回结果是 1 条数据。
  2. 「事务B」插入一条age为21的新用户,提交了事务
  3. 「事务A」第二次读取 age 为 21 的用户,返回结果是 2 条数据(将「事务B」插入的新数据也读出来了)。
3.2、DELETE

在这里插入图片描述

  1. 「事务A」第一次读取 age 为 21 的用户,返回结果是 2 条数据。
  2. 「事务B」删除 id 为 2 的用户,提交了事务
  3. 「事务A」第二次读取 age 为 21 的用户,返回结果是 1 条数据。

4、不可重复度 和 幻读 的区别

不知道大家对「不可重复度」和「幻读」的理解是不是和我一样,感觉非常相近,都是在一个事务中多次读(相同条件),每次结果都不同。对于这 2 个概念有什么区别,我的理解如下:

  1. 「不可重复度」的重点在于 “修改” 操作。
  2. 「幻读」的重点在于 “新增”、“删除” 操作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1237984.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

springboot2自动加载sql文件

文章目录 1. Spring Boot 2 初始化数据库脚本 data.sql & user.sql2. 文件放置的位置 如下表:3. application.yml 配置写法 1. Spring Boot 2 初始化数据库脚本 data.sql & user.sql user.sql :数据表结构 data.sql :数据内容 2. 文…

OpenLayers入门,OpenLayers6的WebGLPointsLayer图层样式和运算符详解,四种symbolType类型案例

专栏目录: OpenLayers入门教程汇总目录 前言 本章讲解使用OpenLayers6的WebGL图层显示大量点情况下,列举出所有WebGLPointsLayer图层所支持的所有样式运算符大全。 补充说明 本篇主要介绍OpenLayers6.x版本的webgl图层,OpenLayers7.x和OpenLayers8.x主要更新内容就是webgl…

wvp-gb28181-pro打包

生成可执行jar cd wvp-GB28181-pro mvn package复制错误已复制 生成war cd wvp-GB28181-pro mvn package -P war 生成的包的路径 wvp-GB28181-pro\target

秋招春招,我没有拿到一个offer怎么办?

看了很多案例,有所感想,也希望这个稿子,能带给大家一些帮助,理想的情况是,我能帮助一些勤劳上进的朋友,对于那些自暴自弃的,可能我无能无力。我想说的是,自己不去做,别人…

做Python自动化测试,我教你个方法还能快一倍!

如果你学过 python 进行自动化测试,你一定使用过 unittest。 今天我们要讲的 nose2 是一个高级版本的 unittest。他比 unittest 更容易理解,用起来也更加方便一些。 快速开始 nose2 在 unittest 的基础上开发的,所以如果你之前是用 unitte…

Leetcode—8.字符串转换整数(atoi)【中等】

2023每日刷题(三十七) Leetcode—8.字符串转换整数(atoi) 算法思想 参考k神的题解 实现代码 int myAtoi(char* s) {int len strlen(s);if(len 0) {return 0;}int boundary INT_MAX / 10;int i 0, ans 0;while(s[i] ) …

云计算实验如何结合AI来提高效率!

随着AI助手的流行,我们现在无论是学习还是工作都会带着一个他/她,如何让AI助手提高我们的工作效率是我们需要进化的方向。下面结合“云计算实验”来分享一下如何让AI帮助我们学得更快学得更好。 一、学习某个软件或复杂命令 比如在学习RockyLinux9.2中…

深入了解Performance API:优化网页性能的利器

在现代Web开发中,优化网页性能是至关重要的。用户对于加载速度和交互性能的要求越来越高,而Performance API作为一组用于测量和监控网页性能的JavaScript接口,为开发者提供了丰富的工具和信息。本文将深入探讨Performance API的各个方面&…

C语言获取win11新版终端WindowsTerminal窗口句柄

随着Win11的普及,越来越多的人都能发现获取控制台窗口不能再使用以下两种传统方法了: HWND hwnd GetConsoleWindow();HWND hwnd FindWindowA("ConsoleWindowClass",NULL);那是因为win11换了新的终端窗口,叫做WindowsTerminal&am…

60V降压恒流芯片 高调光比LED驱动器 SL6015B替代PT4115 电路简单

在LED照明领域,降压恒流芯片是一种非常重要的芯片,它可以将输入的电压降低并输出稳定的电流,从而为LED灯提供合适的驱动电源。其中,SL6015B是一款非常优秀的降压恒流芯片,它具有高调光比、简单的电路设计、低成本的优点…

三柱汉诺塔

题目描述 汉诺塔是约19世纪末,在欧州的商店中出售一种智力玩具。它的结构如下图所示: 在一个平板上立有三根铁针,分别记为A, B, C。开始时,铁针 A 上依次叠放着从大到小 n 个圆盘,游戏的目标就是将 A 上的 n 个圆盘…

在建立 OkHttp3 Client 时设置超时时间

这里写目录标题 一. 前言二. 导入mavengradle 三. 设置超时时间 一. 前言 OkHttp是一个处理网络请求的开源项目,是安卓端最火热的轻量级框架,由移动支付Square公司开发。OkHttp3是Java和Android都能用,Android还有一个著名网络库叫Volley,那个只有Andro…

torch.cat是什么,以及怎么用?

文章目录 一、torch.cat 是什么?二、使用步骤总结 一、torch.cat 是什么? torch.cat 是 PyTorch 中的一个函数,用于沿着某个维度连接张量。 torch.cat 接受一个张量列表,并沿着某个维度连接它们。这个函数会返回一个新的张量&am…

一键合并多个TXT文本,将保存在TXT的快递单号进行一键合并

如果你需要处理大量的TXT文本文件,那么你可能会遇到需要将这些文件合并为一个文件的情况。这不仅涉及到文件的组织和管理,还可能涉及到文件内容的连贯性和完整性。现在,我们有一个强大的工具,可以帮助你轻松实现一键文件整理&…

C/C++结构体给函数传参

C语言中结构体给函数传参有两种方法: 1.值传递(修改形参不改变原值) void fun(STUDENT student){……} int main(){fun(student); }2.引用传递(传的是地址,修改形参会改变原值) void fun(STUDENT * stud…

深入了解Java 8 新特性:Optional类的实践应用

阅读建议 嗨,伙计!刷到这篇文章咱们就是有缘人,在阅读这篇文章前我有一些建议: 本篇文章大概15000多字,预计阅读时间长需10分钟。本篇文章的兼具实战性、理论性,是一篇质量分数较高的技术干货文章&#x…

微服务开发中,使用AOP和自定义注解实现对权限的校验

一、背景 微服务开发中,暴露在外网的接口,为了访问的安全,都是需要在http请求中传入登录时颁发的token。这时候,我们需要有专门用来做校验token并解析用户信息的服务。如下图所示,http请求先经过api网关,网…

【word技巧】Word制作试卷,ABCD选项如何对齐?

使用word文件制作试卷,如何将ABCD选项全部设置对齐?除了一直按空格或者Tab键以外,还有其他方法吗?今天分享如何将ABCD选项对齐。 首先,我们打开【替换和查找】,在查找内容输入空格,然后点击全部…

渗透工具---BurpSuite 插件开发之HelloWorld

本文主要记录如何利用burp官方的新版API即MontoyaApi 写helloworld(上一篇的demo使用旧版api写的,这篇及后续开发将采用新版api) 先看效果图 更多详细内容见下方 这里有更详细更全面的代码内容 以及配置相关的内容 https://mp.weixin.qq.co…

面试题-8

1.vue路由是怎么传参的? params传参 this.$router.push({name:index}) this.$route.params.id 路由属性传参 this.$router.push({name:/index/${item.id}}) 配置路由{path:/index:id} query传参(可以解决页面刷新参数丢失的问题) this.$router.push({ name…