事务的4个特性和4个隔离级别

事务的4个特性和4个隔离级别

    • 1. 什么是事务
    • 2. 事务的ACID特性
      • 2.1 原子性
      • 2.2 一致性
      • 2.3 持久性
      • 2.4 隔离性
    • 3. 事务的创建
    • 4. 事务并发时出现的问题
      • 4.1 DIRTY READ 脏读
      • 4.2 NON - REPEATABLR READ 不可重复读
      • 4.3 PHANTOM READ 幻读
    • 5. 事务的隔离级别
      • 5.1 READ UNCOMMITTED 读未提交
      • 5.2 READ COMMITTD 读已提交
      • 5.3 REPEATABLE 可重复读
      • 5.4 SERIALIZABLE 串行化

1. 什么是事务

事务,简单来说,就是将一组SQL语句组合成一个逻辑单元,这些语句要么全部成功执行,使数据库状态发生预期的改变;要么全部失败,数据库回滚到事务开始前的状态,仿佛这组操作从未发生过。

以日常生活中的转账场景为例,当A向B转账100元时,“A账户减少100元”和“B账户增加100元”这两个操作必须作为一个整体来执行,要么都成功完成转账,要么因为任何原因(如余额不足、网络故障等)都不执行,以保证资金的准确性和一致性。这,就是一个典型的事务。

2. 事务的ACID特性

事务之所以能可靠地管理数据,离不开其具有的四大特性:原子性(Atomicity)、一致性(Consistency)、持久性(Durability)和隔离性(Isolation),简称为ACID特性。

2.1 原子性

原子性确保事务是一个不可分割的最小工作单元。就像化学反应中的原子一样,事务中的所有操作要么一起成功,将数据持久化到数据库;要么一起失败,数据库状态回滚到事务开始之前,不会出现部分操作成功、部分操作失败的中间状态。

2.2 一致性

一致性要求事务执行前后,数据库的完整性约束没有被破坏,数据必须符合业务逻辑和预先设定的规则。例如,在转账事务中,转账前后的账户总金额应该保持不变,这是保证数据一致性的基本体现。

2.3 持久性

一旦事务被成功提交,其所做的修改就会永久性地保存在数据库中。即使后续系统发生故障,如硬件损坏、软件崩溃或断电等,已提交的数据也不会丢失,确保了数据的可靠性和稳定性。

2.4 隔离性

隔离性使得多个并发事务在执行时,相互之间不会产生干扰,每个事务都像是在独立运行。不同的隔离级别决定了事务之间的隔离程度,以及可能出现的并发问题,这将在后续详细讨论。

3. 事务的创建

在SQL语言中,我们可以通过以下语句来灵活地控制事务:

-- 开启一个新的事务,两种方式均可
START TRANSACTION;
-- 或者
BEGIN;

-- 当事务中的所有操作都顺利完成,使用此语句提交事务,将修改永久保存到数据库
COMMIT;

-- 如果在事务执行过程中出现错误或需要回滚操作,执行此语句取消已执行的所有修改
ROLLBACK;

4. 事务并发时出现的问题

当多个事务同时并发执行时,由于事务之间的相互影响,可能会出现以下几种常见的问题:

4.1 DIRTY READ 脏读

脏读是指一个事务读取到了另一个事务尚未提交的数据。如果未提交事务随后回滚,那么读取到的数据就是无效的,这可能导致数据的不一致和错误的业务决策。

4.2 NON - REPEATABLR READ 不可重复读

不可重复读是指在同一个事务中,多次读取同一数据时,由于其他事务在期间对数据进行了修改并提交,导致每次读取的结果不一致。这会给需要在事务中多次读取相同数据进行业务处理的场景带来困扰。

4.3 PHANTOM READ 幻读

幻读是指一个事务在执行过程中,发现另一个事务插入了新的数据,导致该事务再次读取数据时,出现了之前不存在的记录,仿佛产生了“幻觉”。例如在电商下单场景中,用户点击立即购买成功进入下单页面,准备付款时却显示库存不足,这就是幻读的一个典型例子。

5. 事务的隔离级别

为了解决事务并发执行时出现的上述问题,数据库提供了不同的隔离级别,每个隔离级别对并发事务的处理方式和所能避免的问题各不相同。常见的隔离级别有以下4种:

5.1 READ UNCOMMITTED 读未提交

这是最低的隔离级别,允许一个事务读取另一个事务尚未提交的数据。由于此级别几乎没有任何隔离措施,所以可能会出现脏读、不可重复读和幻读等各种并发问题,在实际应用中较少使用。

5.2 READ COMMITTD 读已提交

大多数数据库系统的默认隔离级别。在该级别下,一个事务只能读取其他事务已经提交的数据,可以有效避免脏读问题,但仍然可能出现不可重复读和幻读。

5.3 REPEATABLE 可重复读

MySQL的默认隔离级别。在此级别下,同一个事务内多次读取相同数据时,数据保持一致,能够避免脏读和不可重复读。然而,对于幻读问题,虽然在一定程度上得到了缓解,但并不能完全杜绝。

5.4 SERIALIZABLE 串行化

这是最高的隔离级别,事务会按照顺序依次执行,完全避免了脏读、不可重复读和幻读等所有并发问题。但由于事务串行执行,并发性能较低,适用于对数据一致性要求极高、并发量较低的场景。

通过下面的图片,可以更直观地了解不同隔离级别与并发问题之间的关系:

理解事务的概念、特性、操作以及并发问题和隔离级别,对于开发高效、可靠的数据库应用至关重要。在实际项目中,我们需要根据业务需求和系统性能要求,合理选择事务的隔离级别,以平衡数据一致性和并发性能之间的关系。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Linux中文件目录类指令

1、pwd指令 基本语法:pwd 功能:显示当前工作目录的绝对路径 1.相对路径访问和绝对路径访问 当前处于home目录下,访问a.txt文件 相对路径访问:kim/better/a.txt,从当前位置开始定位 绝对路径访问:/home…

Kafka可视化工具EFAK(Kafka-eagle)安装部署

Kafka Eagle是什么? Kafka Eagle是一款用于监控和管理Apache Kafka的开源系统,它提供了完善的管理页面,例如Broker详情、性能指标趋势、Topic集合、消费者信息等。 源代码地址:https://github.com/smartloli/kafka-eagle 前置条件…

蓝桥杯之日期题

文章目录 1.蓝桥杯必备知识点2. 题型13.需求2 1.蓝桥杯必备知识点 蓝桥杯是一个面向全国高校计算机相关专业学生的学科竞赛,涵盖多个赛道,常见的有软件类(如 C/C 程序设计、Java 软件开发、Python 程序设计)和电子类(…

【算法基础篇】-字符串

字符串篇 一、最长回文子串二、二进制求和三、字符串相乘今日分享这里 一、最长回文子串 最长回文子串 给你一个字符串 s,找到 s 中最长的 回文 子串。 讲解: 我们这里使用的是中心扩展方法,其实类似于暴力枚举,但是时间复杂度…

清华大学DeepSeek文档下载,清华大学deepseek下载(完成版下载)

文章目录 前言一、清华大学DeepSeek使用手册下载二、清华大学DeepSeek使用手册思维导图 前言 这是一篇关于清华大学deepseek使用手册pdf的介绍性文章,主要介绍了DeepSeek的定义、功能、使用方法以及如何通过提示语设计优化AI性能。以下是对这些核心内容的简要概述&…

DeepSeek技术提升,Linux本地部署全攻略

文章目录 1.Ollama部署1.1 安装Ollama1.2 配置Ollama1.3 下载deepseek模型 2.安装MaxKB可视化页面2.1 下载镜像2.2 运行容器2.3 配置MaxKB 3.配置Chatbox AI可视化页面 1.Ollama部署 Ollama下载地址 根据自己需求选择版本下载 1.1 安装Ollama 下载安装脚本并执行 curl -fs…

QSNCTF-WEB做题记录(2)

[第一章 web入门]常见的搜集 来自 <天狩CTF竞赛平台> 1&#xff0c;首先就是对网站进行目录枚举爆破 dirsearch -u http://challenge.qsnctf.com:31616 -x 404,403 得到如下的目录&#xff0c;分别查看一下内容 /.DS_Store /inde…

网络空间安全(1)web应用程序的发展历程

前言 Web应用程序的发展历程是一部技术创新与社会变革交织的长卷&#xff0c;从简单的文档共享系统到如今复杂、交互式、数据驱动的平台&#xff0c;经历了多个重要阶段。 一、起源与初期发展&#xff08;1989-1995年&#xff09; Web的诞生&#xff1a; 1989年&#xff0c;欧洲…

pandas读取数据

pandas读取数据 导入需要的包 import pandas as pd import numpy as np import warnings import oswarnings.filterwarnings(ignore)读取纯文本文件 pd.read_csv 使用默认的标题行、逗号分隔符 import pandas as pd fpath "./datas/ml-latest-small/ratings.csv" 使…

SSL 证书是 SSL 协议实现安全通信的必要组成部分

SSL证书和SSL/TLS协议有着密切的关系&#xff0c;但它们本质上是不同的概念。下面是两者的区别和它们之间的关系的表格&#xff1a; 属性SSL/TLS 协议SSL证书英文全称SSL&#xff08;Secure Sockets Layer&#xff09;&#xff0c;TLS&#xff08;Transport Layer Security&am…

蓝桥杯单片机基础部分——1.5基础模块代码升级

前言 之前的蓝桥杯单片机基础部分——1、基础模块代码发现有的同学不太会使&#xff0c;这样的话就给他们都封装一下函数&#xff0c;额外封装一下蜂鸣器和继电器&#xff0c;这就全了&#xff0c;到时候的逻辑只要没问题就没啥事了 LED灯模块 现在&#xff0c;给这里封装一个…

PCB设计常用布局布线方法

PCB设计常用布局布线方法 **1.模块化布局&#xff0c;**先放大器件再放小器件。 立创在原理图框完后&#xff0c;在PCB快捷shiftp 2.布局对齐美观 3.重要信号线优先处理 分类再画 4.减少Stub布线&#xff1a;就是避免为连接的线段&#xff0c;防止产生“天线效应”&#xff…

基于C++“简单且有效”的“数据库连接池”

前言 数据库连接池在开发中应该是很常用的一个组件&#xff0c;他可以很好的节省连接数据库的时间开销&#xff1b;本文基使用C实现了一个简单的数据库连接池&#xff0c;代码量只有400行只有&#xff0c;但是压力测试效果很好&#xff1b;欢迎收藏 关注&#xff0c;本人将会…

LangChain大模型应用开发:LangGraph快速构建Agent工作流应用

介绍 大家好&#xff0c;博主又来给大家分享知识了。今天给大家分享的内容是使用LangChain进行大规模应用开发中的LangGraph快速构建Agent工作流应用。 通过对前几次对LangChain的技术分享。我们知道LangChain作为一个强大的工具集&#xff0c;为开发者们提供了丰富的资源和便…

基于 IMX6ULL 的环境监测自主调控系统

文章目录 前言一、项目介绍二、前台QT界面1. 界面设计2. 代码示例 三、后台硬件驱动四、JsonRPC 实现前后台分离1. 为什么要拆分&#xff1f;2. 如何拆分&#xff1f; 五、总结 前言 项目完整代码&#xff1a;基于 IMX6ULL 的环境监测自主调控系统完整代码 该项目的源代码适用…

洛谷:花神的数论题--数位dp

求乘积 const int N 1e2 10,T 20;LL n; LL a[N]; LL dp[N][N];//枚举的第i位,没有任何限制,已经填写了j个1的数的乘积 //表示在[pos 1, len]中已经填写了cnt个1&#xff0c;[1, pos]任意填写数&#xff0c;所有合法方案的乘积LL mo(LL x) {return (x % mod mod) % mod; }…

【Linux探索学习】第三十一弹——线程互斥与同步(下):深入理解确保线程安全的机制

线程互斥与同步&#xff08;上&#xff09;&#xff1a;【Linux探索学习】第三十弹——线程互斥与同步&#xff08;上&#xff09;&#xff1a;深入理解线程保证安全的机制-CSDN博客 Linux探索学习&#xff1a; https://blog.csdn.net/2301_80220607/category_12805278.html?…

UVM_CALLBACK 应用举例

UVM_CALLBACK是一种基于回调函数的设计模式&#xff0c;允许用户在特定事件发生时插入自定义的行为。UVM提供了uvm_callback类作为基类&#xff0c;用户可以通过继承该类来定义自己的回调行为。采用uvm_callback基类&#xff0c;用户可以在不更改原始代码的情况下轻松插入调试代…

优选算法大集合(待更新)

1.双指针 1.1.移动零 leetcode链接&#xff1a;283. 移动零 - 力扣&#xff08;LeetCode&#xff09;​​​​​​ 移动零的问题我们可以将它归类为数组划分的问题&#xff0c;我们将数组划分为非零部分和零部分。我们会使用到双指针的算法&#xff0c;在这里&#xff0c;我…

本地大模型编程实战(22)用langchain实现基于SQL数据构建问答系统(1)

使 LLM(大语言模型) 系统能够查询结构化数据与非结构化文本数据在性质上可能不同。后者通常生成可在向量数据库中搜索的文本&#xff0c;而结构化数据的方法通常是让 LLM 编写和执行 DSL&#xff08;例如 SQL&#xff09;中的查询。 我们将演练在使用基于 langchain 链 &#x…