六、事务-5.事务隔离级别

news2024/11/24 10:00:48

一、概念

从上至下,隔离级别越来越高,数据越来越安全,性能越来越低。

  • 读未提交read uncommitted —— 隔离级别最低(数据安全性最差),性能最好
  • 串行化serializable  ——隔离级别最高,性能最差

——一般采取MySQL的默认隔离级别,不会修改。

MySQL默认的隔离级别:可重复读 repeated read

Oracle默认的隔离级别:读已提交 read committed

二、语句

1、查看事务隔离级别

select @@transaction_isolation;

@@  :查看当前系统的变量信息

2、设置事务隔离级别

set  [ session | global ] transaction isolation level {read uncommitted | read committed | repeatable read | serializable}

session: 会话级别,针对当前客户端窗口有效

glonal:针对所有客户端窗口有效

3、演示

三、隔离级别 解决 事务并发问题

两个命令行模拟两个客户端并发操作。

登录MySQL并进入itheima数据库:

1、脏读——只会出现在read uncommitted的隔离级别下

1)左侧设置隔离级别为read uncommitted,并查看accout表中的数据

2)开启事务,左侧select操作,右侧update操作(未提交)

3)左侧再次select操作,张三-1000(读取到右侧未提交的数据:脏读)

4)右侧commit提交,左侧再select查询操作,数据依旧张三-1000,左侧也提交

2、脏读——read committed不会出现脏读问题

1)左侧设置隔离级别为read committed

2) 左右都开启事务,左侧select,右侧update(未提交)

3)左侧再select,张三不会-1000,因为右侧update未提交

read committed隔离级别,不会出现脏读

4)右侧commit,左侧再select ,张三会生效-1000,因为右侧update已提交

3、不可重复读——read committed会出现不可重复读问题

1)左右同时开启事务,左侧select,右侧update

2)左侧再select,张三应为0,因为右侧没提交(read committed不会出现脏读,没提交就读不到)

3)右侧commit提交,左侧select,可以查到张三为1000,因为右侧update已提交

4)在左侧命令行中,同一select命令执行三次,第三次的结果和前两次不一致——不可重复读问题

4、不可重复读——repeatable read不会出现不可重复读问题

1)左侧设置隔离级别为repeatable read,左右都开启事务

2)左侧select,右侧update并直接提交

3)左侧再select,查询结果张三仍是1000,不受右侧的影响(同一个SQL语句结果相同)——可重复读

4)左侧commit提交,再select,张三数据才会更新为2000

5、幻读——repeatable read会出现幻读问题

1)左右都开启事务,左侧select查询id为3的数据(无id为3的数据)

2)右侧insert插入id为3的数据,并直接提交(此时account表中有id为3的数据)

3)左侧由于刚刚查了没有id为3的数据,此时insert插入id为3的数据,会报错:account表中的主键id为3重复了

4)左侧再select查id为3的数据,依旧查不到——幻读:查又查不到,插入又报错

5)左侧提交commit,结束事务

6、幻读——serializable不会出现幻读问题

1)左侧设置隔离级别为serializable,左右开启事务

 2)左侧select查询id为4的数据(无id为4的数据),

3)右侧insert插入一条id为4的数据,执行光标一直在闪,表示阻塞了

因为此时左侧的事务正在操作,右侧的事务就得等,要等左侧事务执行完成并提交后,右侧才可操作。

4)左侧insert插入id为4的数据并提交,右侧之前光标闪的地方出现error结果(id为4已存在)

5)右侧commit提交,结束事务

串行化——并发事务操作时,只允许一次一个事务来操作,A事务在操作时,B事务要等,只有A事务提交后,B事务才能操作。

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

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

相关文章

【GNN+异常检测】Deep Anomaly Detection on Attributed Networks

文章目录 论文简介摘要属性网络相关介绍存在的问题论文贡献1. 提出的模型 - Dominant2. 实验 论文简介 原文题目:Deep Anomaly Detection on Attributed Networks 中文题目:基于属性网络的深度异常检测 发表会议:SIAM International Conferen…

Java“魂牵”京东店铺所有商品数据接口,京东店铺所有商品API接口,京东API接口申请指南

要通过京东的API获取店铺所有商品数据,您可以使用京东开放平台提供的接口来实现。以下是一种使用Java编程语言实现的示例,展示如何通过京东开放平台API获取整店商品数据: 首先,确保您已注册成为京东开放平台的开发者,…

快速提升代码性能:FastAPI多线程的利用

在现代网络应用中,高性能和快速响应是至关重要的,Python 的 FastAPI 框架以其出色的性能和简单易用的特点,成为了许多开发者的首选。然而,在某些场景下,单线程运行可能无法满足需求,这时候就需要考虑使用多…

【AutoLayout案例08-基于AutoLayout的动画 Objective-C语言】

一、好,那么,再给大家说一个什么呢 1.再给大家说一个,这么一个东西, 我们之前,通过frame,是不是可以通过animateWithDuration,可以执行动画吧 通过直接设置frame的方式,可以执行动画, 我们这里,通过约束,的方式, 也可以执行动画, 通过约束,也可以执行动画, …

基于FlaUI自动化+chatGPT实现微信自动回复

先看效果图 本次主要介绍如何实现自动回复: 1.将文件传输助手置顶,模拟鼠标点击文件传输助手; 2.一直刷新会话列表,有新的消息就需要回复内容; 3.当刷新到新的消息时,模拟鼠标点击到对应的会话人&#x…

擦除信道(erasure channel)

定义 二进制擦除通道(BEC)是一种信道模型。发送端发送一个比特(0或1),接收端要么正确接收该比特(0或1),要么以概率 P e P_{e} Pe​接收到该比特没有被接收的信息(即“擦除…

公司电脑文件数据透明加密、防泄密系统

一套利用驱动层透明加密技术实现电子文件安全加密的防护产品,从源头上保障数据安全和使用安全的加密系统。该系统遵循基于文件生命周期安全防护的思想,集成了密码学、访问控制和审计跟踪等技术手段,对企事业单位电子文件的存储、访问、传播和…

【UE 材质】实现角度渐变材质、棋盘纹理材质

目标 步骤 一、角度渐变材质 1. 首先通过“Mask”节点将"Texture Coordinate" 节点的R、G通道分离 2. 通过“RemapValueRange”节点将0~1范围映射到-1~1 可以看到此时R通道效果: G通道效果: 继续补充如下节点 二、棋盘纹理材质 原视频链接&…

Docker(三) 创建Docker镜像

一、在Docker中拉取最基本的Ubuntu系统镜像 搜索Ubuntu镜像 Explore Dockers Container Image Repository | Docker Hub 下载镜像 docker pull ubuntu:22.04 二、在镜像中添加自己的内容 使用ubuntu镜像创建容器 docker run -it ubuntu:20.04 /bin/bash 在容器中创建了一个文…

成集云 | 多维表格自动化管理jira Server项目 | 解决方案

源系统成集云目标系统 方案介绍 基于成集云集成平台,在多维表格中的需求任务信息自动创建、更新同步至 Jira Server 的指定项目中,实现多维表格中一表管理 Jira Server 中的项目进度。 维格表是一种新一代的团队数据协作和项目管理工具&…

day-01 Docker

一、docker简介 Docker 是一种开源的容器化平台,它可以帮助开发人员将应用程序及其依赖项打包成一个独立的、可移植的容器,而无需担心环境差异和依赖问题。通过使用 Docker,您可以更轻松地创建、分发和运行应用程序,无论是在开发、…

Apipost: 开发者们的瑞士军刀

在当今的数字化时代,数据流通是推动社会进步的关键因素之一。其中,API(应用编程接口)已经成为跨平台数据交互的标准。然而,API开发和管理并非易事,Apipost一体化研发协作赋能平台,支持从API设计…

并发编程(四)---死锁 synchronized、volatile详解

一.关键字 1.synchronized关键字: a.重量级锁,功能完整的锁 b.修饰类、方法、静态方法、代码块,但不可以在声明的时候修饰 c.synchronized是实现同步的基础,Java中不管是对象还是方法,都可加上锁。synchronized分为三…

音频应用编程

目录 ALSA 概述alsa-lib 简介sound 设备节点alsa-lib 移植编写一个简单地alsa-lib 应用程序一些基本概念打开PCM 设备设置硬件参数 ALPHA I.MX6U 开发板支持音频,板上搭载了音频编解码芯片WM8960,支持播放以及录音功能! 本章我们来学习Linux …

探索散列表和哈希表:高效存储与快速检索的魔法

文章目录 散列函数的原理散列表和哈希表的概念与操作解决冲突的方法案例分析:电话簿的实现拓展:性能与碰撞结论 🎉欢迎来到数据结构学习专栏~探索散列表和哈希表:高效存储与快速检索的魔法 ☆* o(≧▽≦)o *☆嗨~我是IT陈寒&#…

【模拟集成电路】反馈系统加载效应——基础到进阶(三)

【模拟集成电路】反馈系统加载效应——基础到进阶(三) -----------------------文末附往期文章链接-------------------- 1.概述2.二端口网络方法2.1二端口网络模型2.2电压-电压反馈的加载2.2电流-电压反馈的加载2.3电压-电流反馈的加载2.4电流-电流反馈…

一文速学-让神经网络不再神秘,一天速学神经网络基础-输出层(四)

前言 思索了很久到底要不要出深度学习内容,毕竟在数学建模专栏里边的机器学习内容还有一大半算法没有更新,很多坑都没有填满,而且现在深度学习的文章和学习课程都十分的多,我考虑了很久决定还是得出神经网络系列文章,不…

Flutter 混合开发调试

针对Flutter开发的同学来说,大部分的应用还是Native Flutter的混合开发,所以每次改完Flutter代码,运行整个项目无疑是很费时间的。所以Flutter官方也给我们提供了混合调试的方案【在混合开发模式下进行调试】,这里以Android Stud…

Python基础学习第四天:Python注释

创建注释 注释以 # 开头,Python 将忽略它们: 实例 #This is a comment print("Hello, World!")运行实例 注释可以放在一行的末尾,Python 将忽略该行的其余部分: 实例 print("Hello, World!")…