【SQL】ACID事务与隔离级别

数据库事务

数据库事务具有ACID这4个特性:

  • A:Atomicity,原子性,将所有SQL作为原子工作单元执行,要么全部执行,要么全部不执行;
  • C:Consistency,一致性,事务完成后,所有数据的状态都是一致的,即A账户只要减去了100,B账户则必定加上了100;
  • I:Isolation,隔离性,如果有多个事务并发执行,每个事务作出的修改必须与其他事务隔离;
  • D:Durability,持久性,即事务完成后,对数据库数据的修改被持久化存储。

事务分为隐式事务和显式事务

  • 隐式事务
    对于单条SQL语句,数据库系统自动将其作为一个事务执行,这种事务被称为隐式事务。
  • 显式事务
    手动把多条SQL语句作为一个事务执行,使用BEGIN开启一个事务,使用COMMIT提交一个事务,这种事务被称为显式事务
    BEGIN;
    UPDATE accounts SET balance = balance - 100 WHERE id = 1;
    UPDATE accounts SET balance = balance + 100 WHERE id = 2;
    COMMIT;/ROLLBACK; -- ROLLBACK可以使事务失败
    

隔离级别

分别对应可能出现的数据不一致的情况:

Isolation Level(隔离级别)脏读(Dirty Read)不可重复读(Non Repeatable Read)幻读(Phantom Read)
Read Uncommitted(读未提交)YesYesYes
Read Committed (读已提交)-YesYes
Repeatable Read (可重复读)--Yes
Serializable (串行化)---

接下来依次介绍4种隔离级别的数据一致性问题:

Read Uncommitted(读未提交)

  • 描述:这是最低的隔离级别,在该级别下,一个事务可以读取另一个事务未提交的数据。
  • 数据一致性问题:
    • 脏读(Dirty Reads):一个事务可能读取另一个事务未提交的更改。如果这些更改最终被回滚,则读取的数据是无效的。
    • 不可重复读(Non-Repeatable Reads):在同一事务中,同一查询可能返回不同结果,因为其他事务正在更改数据。
    • 幻读(Phantom Reads):在同一事务中执行相同的查询,由于其他事务添加或删除了符合查询条件的行,所返回的结果集可能会不同。

Read Committed(读已提交)

  • 描述:这个级别允许在一个事务内执行的查询只看到已经提交的更改。
  • 数据一致性问题:
    • 不可重复读:同一个事务内两次执行相同的查询可能会得到不同的结果,因为其他事务可能在两次查询之间提交了更新。
    • 幻读:可能会出现,因为其他事务插入或删除了符合查询条件的行。

Repeatable Read(可重复读)

  • 描述:保证在同一事务内的查询可以多次执行并返回相同的结果,即使其他事务在此期间提交了更新。
  • 数据一致性问题:
    • 幻读:尽管同一事务中的同一查询会返回一致的结果集,但如果其他事务添加或删除了符合查询条件的行,还是可能出现幻读问题。这是因为新插入的行(“幻影行”)可能被包含在后续的查询结果中。

Serializable(串行化)

  • 描述:这是最高的隔离级别。它通过强制事务串行执行来避免幻读,确保一个事务完全执行完毕后,另一个事务才能开始执行。
  • 数据一致性问题:
    • 在串行化隔离级别下,理论上不会遇到脏读、不可重复读或幻读这类的数据一致性问题。这是因为事务是顺序执行的,每个事务都是在前一个事务完成后才开始,从而避免了数据在不同事务间的不一致性。

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

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

相关文章

04-18 周四 为LLM_inference项目配置GitHub CI过程记录

04-18 周四 为LLM_inference项目配置GitHub CI过程记录 时间版本修改人描述2024年4月18日10:30:13V0.1宋全恒新建文档 简介和相关文档 04-15 周一 GitHub仓库CI服务器配置过程文档actions-runner 是托管与GitHub上的仓库,下载最新的客户端程序即可。self hosted r…

一个年薪30w软件测试员的职业规划,献给还在迷茫中的朋友

先抛出一个观点 , 那些,担心30岁后,35岁后,40岁后,无路可走的;基本属于能力不够、或者思维太局限 。 总之,瞎担心 / 不长进 。 具体,见下面正文 。 曾经,在16年&#xff…

AI技术赋能下的视频监控方案是如何解决新能源汽车充电难问题的?

一、方案背景 刚刚结束的第十八届北京车展异常火爆,其中一组与汽车有关的数字让人格外关注。根据乘联会2024年4月19日公布的最新数据,全国乘用车市场零售达到51.6万辆,其中新能源车的销量约为26万辆,市场渗透率达到50.39%。 这意味…

国产化操作系统都有哪些?如何选择?

国产化操作系统主要包括以下几种: 深度Linux(Deepin):基于Linux内核,已具备相对完善的产品体系,并广泛应用于关键领域。统信UOS(统一操作系统):支持多种国产CPU平台&…

音视频开发4 FFmpeg windows 环境搭建,QT 安装,动态库的搜索路径

FFmpeg 为了让所有平台的开发者都能够学习到音视频开发的通用技术,本教程主要讲解跨平台的音视频开发库FFmpeg。其实只要你掌握了FFmpeg,也可以很快上手其他音视频开发库,因为底层原理都是一样的,你最终操作的都是一样的数据&…

【第10章】spring-mvc转发和重定向

文章目录 前言一、准备二、转发1. 视图解析器(推荐)2. 关键字(forward)3. request 三、重定向1.关键字(redirect)2. HttpServletResponse 四、区别总结 前言 前面介绍了视图解析器的使用,但是对我们原有转发和重定向有影响,接下来我们通过案例,来使用学习转发和重定向的用法。…

ComfyUI 基础教程(十四):ComfyUI中4种实现局部重绘方法

在ComfyUI中有多种方式可以实现局部重绘,简单的方式是使用VAE内补编码器进行局部重绘,也可以用Fooocus inpaint进行局部重绘,还可以用controlNet的inpaint模型进行局部重绘,以及使用Clip seg蒙版插件! 本篇介绍使用VAE內补编码器进行局部重绘的方法。 1、VAE内补编码器 局…

《架构风清扬-Java面试系列第28讲》聊聊SynchronousQueue的使用及适合场景

SynchronousQueue是BlockingQueue接口的一个实现类之一 这个属于基础性问题,老规矩,我们将从使用场景和代码示例来进行讲解 来,思考片刻,给出你的答案 1,使用场景 实现:特殊的无缓冲队列,每一个…

帆软报表9.0连接达梦数据库

一、将驱动复制到帆软安装目录下 二、配置数据库连接 注意:dm.jdbc.driver.DmDriver是直接在文本框输入的 进行以上两部就能连接达梦数据库了

深度学习的核心数学知识点

深度学习的数学知识点包括但不限于以下几个方面: 线性代数: 标量、向量、矩阵和张量:这些是线性代数的基础元素。标量是一个单独的数,向量是有序的数字列表,矩阵是二维数字网格,而张量则是更高维度的数据容…

揭秘!如何利用自动化工具提升抖音推广效果

亲爱的读者朋友们,你是否在为抖音的推广效果而苦恼?看着别人家的视频轻松获得大量曝光,你是否也心生羡慕?今天,我们就来分享一个秘密武器,让你轻松提升抖音推广效果! 首先,让我们来了…

开发环境待

一 web开发环境搭建 1 web开发环境概述 所谓web开发,指的就是从网页中向后端程序发送请求.与后端程序进行交互. 流程图: 1,Web服务器是指驻留于因特网上某种类型计算机的程序. 2, 可以向浏览器等Web客户端提供文档,也可以放置网站文件,让全世界 浏览…

微信答题活动怎么做_智慧与惊喜的碰撞

在这个信息爆炸的时代,如何吸引用户的眼球,让他们在众多品牌中驻足停留?答案或许就藏在一次别开生面的微信答题活动中。今天,就让我们一起走进这场以智慧与惊喜为主题的微信答题狂欢夜,感受其带来的独特魅力。 工具/原…

AI预测福彩3D第10套算法实战化赚米验证第2弹2024年5月6日第2次测试

由于今天白天事情比较多,回来比较晚了,趁着还未开奖,赶紧把预测结果发出来吧~今天是第2次测试~ 2024年5月6日福彩3D预测结果 6-7码定位方案如下: 百位:3、4、1、7、8、9 十位:4、5、3、7、8、9 个位&#x…

JS基础:输出信息的5种方式详解

你好,我是云桃桃。 一个希望帮助更多朋友快速入门 WEB 前端的程序媛。 云桃桃-大专生,一枚程序媛,感谢关注。回复 “前端基础题”,可免费获得前端基础 100 题汇总,回复 “前端基础路线”,可获取完整web基础…

python3+requests+unittest实战系列【一】

1.环境准备 python3 pycharm编辑器 2.框架目录展示 (该套代码只是简单入门,有兴趣的可以不断后期完善) 1)run.py主运行文件,运行之后可以生成相应的测试报告,并以邮件形式发送; &#xff0…

【电商-虾皮】

电商-虾皮 ■ 人口分布■ 市场■ 欧美市场■ 东南亚市场■ 运营模式■ 流量来源■ ERP辅助软件■■ 选品方法■■■ 人口分布 ■ 市场 ■ 欧美市场 亚马逊 ■ 东南亚市场 shopee ■ 运营模式 ■ 流量来源

Matlab 手写板设计

写字板 1、介绍 MATLAB手写板可以作为一个很好的数据输入口,其可以获取该手写板上任意字母、数字,甚至可以制作样本数据。具体用途体现在如下几方面: 数学公式输入:手写板允许用户直接用手写方式输入复杂的数学公式,这…

JavaScript中Math函数与舍入

立方根 console.log(Math.sqrt(25)); //数学方式25平方根 console.log(25 ** (1 / 2)); //25的0.5次方 console.log(8 ** (1 / 3)); //8的1/3次方计算最大最小值 console.log(Math.max(1, 5, 88, 22, 132)); //返回最大值 console.log(Math.max(1, 5, 88, 22, 132)); //…

学习java第六十天

Advice的类型: (1)前置通知(Before Advice):在连接点(Join point)之前执行的通知。 (2)后置通知(After Advice):当连接点退…