数据库四种隔离等级

news2024/12/28 18:17:08

持续更新以及完善中…

数据库事务隔离

首先,为什么要有事务隔离呢?

在单线程下,没什么大碍,但是我们想要提高效率,采用多线程并发时,便会出现一些问题。

**下面的问题一定要当作一个事务来看待!!!!**不要觉得连续两次查询就是一次事务了,这里的两次查询是处于同一个事务,你可以当作两次查询一次是写在函数开头,一次是写在了函数末尾。

void task(){
    selectBySql();
    
    .....干了其他事情,或者没干。
    
    
    selectBySql();
}
  • 脏写

A有100块,现在给自己又转了20(就变成120了),现在B给A转了20块(变成了140),但是A转给自己20的事务因为某些原因出错导致回滚,又变成了100块。导致B不管先一步提交(120)还是后一步提交(140),都不是120块。

  • 脏读

A转给自己20块,B读取了A资产发现有120块,但是A又因为某些问题导致回滚,B再去读A的资产发现变成了100块

  • 不可重复读

在这里插入图片描述

  • 幻读

A查询比自己财产更多的用户,发现只有C用户。

这个时候B和D用户开了账户,并转了很多钱进去。

A再次查询比自己财产更多的用户,发现出现了C,B,D用户(这是上次读取时未出现过的啊)

read uncommit(读未提交)

Oracle默认隔离规则。(效率高)

读数据不需要锁,写数据需要锁。

解决了脏写问题(写操作互斥)

但是出现脏读问题。

read commit(读已提交)

MySQL默认隔离规则(效率较高)。

只有更新事务成功提交,才能查询到本次更新.

A转账给自己20(初始100块),必须提交成功,其他人查询A的资产时才能看到120块.

解决脏读问题.

插播一条(MVCC)

MVCC

mutil version concurrent control

多版本并发控制,同一时刻同一条记录在系统中可以存在多个版本

只有当写数据事务提交时,才能读到最新的数据。

通过Read View (一致性视图)。

害,东西太多太多了,本人现在的理解就是。

初始阶段,A的资产记录是version1.0。 A执行更新的事务(更新到version2.0),然后B去读A的资产,只要是A执行更新事务没有提交,只能读到version1.0的数据。当A回滚时不会出现问题,当A提交后数据库中A资产数据更新到version2.0,但B需要提交本次查询事务,在下一次查询的时候才能看到version2.0的数据…

REPEATABLE READ(可重复读)

在整个事务过程中该事务看到的记录,自始至终都是一样的。

A转账给自己20(初始100块),必须提交成功

其他人查询A的资产时的事务也提交后,随后的查询事务才能读取到120块.

serializable (串行)

解决所有问题。但是效率最低,无并发,读和写都需要上锁。

画饼


看到舍友们在复习数据库期末考试, 然后想到上学期学的时候对于事务以及并发这里学校并未怎么讲到.

然后学后端现在也开始进入到处理分布式,并发这些问题了.

先给自己挖一个数据库学习的坑吧.

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

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

相关文章

高考之后第一张大流量卡应该怎么选?

高考之后第一张大流量卡应该怎么选? 高考结束后,选择一张合适的大流量卡对于准大学生来说非常重要,因为假期期间流量的使用可能会暴增。需要综合考虑多个因素,以确保选到最适合自己需求、性价比较高且稳定的套餐。以下是一些建议…

MAVEN架构项目管理工具

1、什么是maven Maven是跨平台的项目管理工具。主要服务于基于Java平台的项目构建,依赖管理和项目信息管理。 2、maven的目标:Maven的主要目标是为了使开发人员在最短的时间内领会项目的所有状态 3、使用maven不需要考虑各个依赖的版本,因…

指针(初阶2)“野指针以及指针运算”

目录 一.野指针 二.如何避免野指针 三.指针运算 1、指针(-)整数 2、指针 - 指针 3、指针关系运算 小编在这里声明一下,将某一块的知识点分为上中下或者1,2,3来编写不是为了增加小编的文章总量,也不是故意这…

MySQL之多表查询—列子查询

一、引言 标量子查询上篇博客已学习。接下来这篇博客学习子查询的第二种形式——列子查询 列子查询 子查询返回的结果是一列(当然也可以是多行),这种子查询称为列子查询。 列子查询可以使用的操作符 IN、NOT IN 、ANY(any)、SOME…

windows域控共享网络驱动器

背景 假设在一家公司,有新入职的员工。我们给其创建了域账号,有一些共享的文件需要其可以直接访问到。我们可以采用共享目录的形式,但是每次都要输入共享端的ip或者主机名,比较麻烦。我们希望创建的域账号访问共享文件更便捷一些…

使用Flask框架在Python中获取HTTP请求头信息

目录 引言 一、Flask框架简介 二、获取HTTP请求头的方法 三、案例分析 案例一:基于请求头进行用户身份验证 案例二:基于请求头的内容类型处理不同格式的响应 四、总结 引言 在Web开发领域,HTTP协议是客户端和服务器之间进行通信的基础…

爆破信息壁垒!多少考研人还在盲目刷题?

有些同学,天生擅长冲锋陷阵,不擅长思考总结。 忌:看视频一日千里,看例题从不动笔。 —— 新知识都“会”,旧知识都不会。 大忌:做题没思路,一看答案都会! 24的学长学姐&#xff0c…

抽象的java入门1.3.2

前言: 全新版本的函数(方法)定义,更简单 1.优化了验证过程,直击本质 2.新增目前一图流 正片: 函数的结构可以分为三部分:函数名,参数,函数体 一生二,二生…

VS2019专业版 C#和MFC安装

1. VS2019专业版下载地址 https://learn.microsoft.com/en-us/visualstudio/releases/2019/history 2.安装 C# 部分 MFC部分

ATTCK红队评估(五)

环境搭建 靶场拓扑图: 靶机下载地址: 漏洞详情 外网信息收集 确定目标靶机地址: 发现主机192.168.135.150主机是本次攻击的目标地址。探测靶机开放的端口信息: 目标靶机开放了两个端口:80、3306,那没什么意外的话就是…

服务部署:.NET项目使用Docker构建镜像与部署

前提条件 安装Docker:确保你的Linux系统上已经安装了Docker。如果没有,请参考官方文档进行安装。 步骤一:准备项目文件 将你的.NET项目从Windows系统复制到Linux系统。你可以使用Git、SCP等工具来完成这个操作。如何是使用virtualbox虚拟电…

2024年6月8日 每周新增游戏

中医百科中药: 中医百科中药是一款非常强大的中药知识科普软件,该应用提供500多味中草药的文献资料,强大的搜索功能可根据功效、特点和关键词来快速查找中药,而且每味中药的图片、功效、主治、炮制方法等百科知识,可以很好的帮助你…

深入理解指针(三)

一、指针运算 1.1指针-整数 下面我们来看一个指针加整数的例子&#xff1a; #include<stdio.h> int main() { int arr[10] { 1,2,3,4,5,6,7,8,9,10 }; int* p &arr[0]; int i 0; int sz sizeof(arr) / sizeof(arr[0]); for (i 0; i < …

QT c++ 堆栈一些理解--限制对象建立在栈上--栈堆区别

图示形象化理解&#xff1a; 堆栈都是数据结构存取数据的方式 堆&#xff1a;理解为一个堆积物体&#xff0c;独立的分散的&#xff0c;当需要空间时&#xff0c;再找一个地方。需要的就是new关键字&#xff0c;动态申请一个空间。程序员自己动态分配空间&#xff0c;使用指针…

最近很多朋友都消失了。。。

你好&#xff0c;我是郭震 1 聊聊现状 最近听到一些铁铁们&#xff0c;跟我聊&#xff0c;聊到现在的工作情况。 有的工作几年被裁&#xff0c;现在待业找工作。 还有些学校毕业目前未找到工作。 还有一些从上海、北京离开回老家了。 关注我的很多都是IT相关或对编程学习感兴趣…

(南京观海微电子)——液晶画面Crosstalk的原理与本质分析

一、H-Crosstalk (与EE开发相关) 1.画面轻重载切换交界处有水平弱线或Block – Power IC 相关 – Root cause&#xff1a;AVDD drop 后恢复过慢 – Solution : Power IC 补偿调整优化 范例&#xff1a;AVDD在重载区Drop明显&#xff0c;且恢复较慢导致的Hcrosstalk&#xff1b;…

目录穿越漏洞CVE-2018-7171复现 又学到一招小技巧!!!!

还是半夜睡不着&#xff0c;打开靶机开始操作。今天看了文件下载和目录穿越漏洞想结合以及防御方法。半夜来进行操作一波。复现一下漏洞&#xff0c;这个网上的文章页比较的少&#xff01;&#xff01;&#xff01; 开始操作起来&#xff01;&#xff01;&#xff01; 进入到页…

Vue3中的常见组件通信之`$refs`、`$parent`

Vue3中的常见组件通信之$refs、$parent 概述 ​ 在vue3中常见的组件通信有props、mitt、v-model、 r e f s 、 refs、 refs、parent、provide、inject、pinia、slot等。不同的组件关系用不同的传递方式。常见的撘配形式如下表所示。 组件关系传递方式父传子1. props2. v-mod…

Linux “ 软件管理 “

软件管理 widows 安装 方法一&#xff1a; 双击exe安装包&#xff0c;就可以安装。 用exe安装的软件会破记录到注册表中。 注册会记录安装位置&#xff0c;软件名称。 方法二&#xff1a; 用绿色方式进行安装。 不用写到注册表中&#xff0c;因此无法在开始菜单里面查看和卸…

javascript二进制流转图片的操作方法:File、Blob、FileReader、ArrayBuffer、Base64格式之间的转换

文章目录 引言I 使用img标签来加载图片1.1 使用img标签来加载图片1.2 在加载图片时进行身份验证: sign/AuthorizationII 跨域请求中包含凭证2.1 Fetch API在跨域请求中包含凭证2.2 ajax在跨域请求中包含凭证III 显示图片方式3.1 创建一个URL指向这个Blob对象3.2 获取ArrayBuff…