【数据库】事务

news2025/7/3 13:42:55

目录

1. 什么是事务?

2. 事务的ACID特性

3. 为什么使用事务?

4. 如何使用事务

4.1 查看支持事务的存储引擎

4.2 语法

4.3 保存点

4.4 自动/手动提交事务

5. 事物的隔离性和隔离级别

5.1 什么是隔离性

5.2 隔离级别

5.3 查看和设置隔离级别


1. 什么是事务?

事务保证数据安全,索引提升查询效率

事务把一组SQL语句打包成一个整体,在这组SQL执行过程中,要么全部成功,要么全部失败,这组SQL语句可以是一条也可以是多条。

2. 事务的ACID特性

事务的ACID特性是指Atomicity(原子性)、Consistency(一致性)、Isolation(隔离性)和Durability(持久性)。

Atomicity(原子性):一个事务中的所有操作,要么全部成功要么全部失败,不会出现执行一半的情况,如果事务在执行过程中发生错误,会回滚(Rollback)到事务开始前的状态,就像这个事务没有执行过。原子性是支持事务的数据库中最基本的一个特性。

Consistency(一致性):事务执行完成后,保证数据正确且符合预期,数据库的完整性不会被破坏。写入的数据必须完全符合所有的预设规则,包括数据的精度、关联性以及关于事务执行过程中服务器崩溃后如何恢复。

Isolation(隔离性):多个事务之间不能相互影响。数据库允许多个并发事务同时对数据进行读写和修改,隔离性可以防止多个事务并发执行时由于交叉执行而导致数据的不一致。事务可以指定不同的隔离级别,以权衡在不同的应用场景下数据库性能和安全。

Durability(持久性):事务一旦提交,将会保存在存储介质中,即使数据库损坏也不会影响数据的安全。事务处理结束后,对数据的修改将永久写入存储介质,即便系统故障也不会丢失。

事务最终要保证一致性:一致性通过原子性、隔离性和持久性来实现

3. 为什么使用事务?

事务具备的ACID特性,使得支持事务的数据库能够简化我们的编程模型,不需要考虑各种各样的潜在错误和并发问题,在使用事务时,要么提交要么回滚,不用考虑网络异常、服务器宕机等其他因素,因此我们接触的事务本质上是数据库对ACID模型的一个实现,为应用层服务。

4. 如何使用事务

4.1 查看支持事务的存储引擎

MySQL支持事务的存储引擎是InnoDB,可以通过show engines;查看:

4.2 语法
-- 开始一个新的事务
start transaction;
-- 或
begin;

-- 提交当前事务,并对更改持久化保存
-- commit之后不能再回滚,因为事务已经提交,数据已落盘
commit;

-- 无论提交还是回滚,事务都会关闭

-- 回滚当前事务,取消其更改(撤销所有操作,回到事务开始之前)
rollback;
4.3 保存点

在事务执行的过程中设置保存点,回滚时指定保存点可以把数据恢复到保存点的状态

-- 设置保存点
savepoint point1;
-- 回滚到第二个保存点
rollback to point2;
-- 如果只写rollback就会回滚到事务最开始
rollback;
4.4 自动/手动提交事务

默认情况下事务自动提交和回滚(发生异常时)。一个事务只包含一条DML语句

查看事务是否自动提交可以使用以下语句:

on表示自动提交开启

可以通过以下语句设置事务为自动或手动提交:

注意:

  1. 只要使用start transaction或begin开启事务,必须通过commit提交才会持久化,与是否设置set autocommit无关
  2. 手动提交模式下,不用显示开启事务,执行修改操作后,提交或回滚事务时直接使用commit或rollback
  3. 已提交的事务不能回滚

5. 事物的隔离性和隔离级别

5.1 什么是隔离性

不同的客户端对同一张表进行数据修改时可能出现相互影响的情况,为了保证不同事物之间在执行过程中不受影响,事物之间需要进行隔离,这种特性称为隔离性

5.2 隔离级别

事务间不同程度的隔离称为事务的隔离级别。不同隔离级别在性能和安全方面做了取舍,有的隔离级别注重并发性、有的注重安全性、有的并发和安全适中。MySQL的InnoDB引擎中事务的隔离级别有四种:

  • read uncommitted,读未提交(安全性最低、性能最高)(会出现“脏读”现象:事务A对数据进行修改,事务B访问事务A未提交的数据)
  • read committed,读已提交(会出现“不可重复读”现象:事务A第一次查询某条记录,事务B对此条记录进行修改并提交,事务A再次查询这条记录时,与第一次查询结果不一致)
  • repeatable read,可重复读(默认)(会出现“幻读”现象:两次查询得到的结果集不同)(InnoDB存储引擎中,使用了next-key锁,锁住了目标行和之前的间隙,解决了部分的幻读问题)
  • serializable,串行化(安全性最高、性能最低)(解决了所有的数据安全问题,所有事务都是一个挨一个执行,一个事务必须要等到上一个事务执行完才能执行)

5.3 查看和设置隔离级别

事务的隔离级别分为全局作用域会话作用域,查看不同作用域事务的隔离级别,可以使用以下方式:

# 全局作用域
select @@global.transaction_isolation;
# 会话作用域
select @@session.transaction_isolation;

可以看到默认的事务隔离级别是repeatable-read(可重复读)

# 通过global|session分别指定不同作用域的事务隔离级别
set [global|session] transaction isolation level level|access_mode;

# 隔离级别
level:{
    repeatable read  # 可重复读
  | read committed   # 读已提交
  | read uncommitted # 读未提交
  | serializable     # 串行化
}

# 访问模式
access_mode:{
    read write #表示事务可以对数据进行读写
  | read only  #表示事务只读,不能对数据进行读写
}

# 示例
# 设置全局事务隔离级别为串行化,后续所有事务生效,不影响当前事务
set global transaction isolation level serializable;
# 设置会话事务隔离级别为串行化,当前会话后续的所有事务生效,不影响当前事务,可以在任何时候执行
set session transaction isolation level serializable;
# 如果不指定任何作用域,设置只针对下一个事务,随后的事务恢复之前的隔离级别
set transaction isolation level serializable;
# 方式一
set global transaction_isolation='serializable';
# 注意使用set语法时有空格要用'-'代替
set session transaction_isolation='repeatable-read';

# 方式二
set @@global.transaction_isolation='serializable';
# 注意使用set语法时有空格要用'-'代替
set @@session.transaction_isolation='repeatable-read';

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

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

相关文章

使用Redis实现实时排行榜

为了实现一个实时排行榜系统,我们可以使用Redis的有序集合(ZSet),其底层通常是使用跳跃表实现的。有序集合允许我们按照分数(score)对成员(member)进行排序,因此非常适合…

6. 字符串

1.反转字符串 2.替换数字 3.反转字符串中的单词 4.KMP算法 5.重复的子字符串(看具体证明) 太6了(真不是人做的)

Redis ④-通用命令

Redis 是一个 客户端-服务器 结构的程序,这与 MySQL 是类似的,这点需要牢记!!! Redis 固然好,但也不是任何场景都适合使用 Redis,一定要根据当前的业务需求来选择是否使用 Redis Redis 通用命令…

卷积神经网络(CNN)与VGG16在图像识别中的实验设计与思路

卷积神经网络(CNN)与VGG16在图像识别中的实验设计与思路 以下从基础原理、VGG16架构解析、实验设计步骤三个层面展开说明,结合代码示例与关键参数设置,帮助理解其应用逻辑。 一、CNN与VGG16的核心差异 基础CNN结构 通常包含33~55个…

玩机搞机基本常识-------小米OLED屏幕机型怎么设置为永不休眠_手机不息屏_保持亮屏功能 拒绝“烧屏” ?

前面在帮一位粉丝解决小米OLED机型在设置----锁屏下没有永不休眠的问题。在这里,大家要明白为什么有些小米机型有这个设置有的没有的原因。区分OLED 屏幕和 LCD屏幕的不同。从根本上拒绝烧屏问题。 OLED 屏幕的一些优缺点💝💝💝 …

2021-11-14 C++三七二十一数

缘由c编程怎么写&#xff0c;紧急求解-编程语言-CSDN问答 void 三七二十一数() {//缘由https://ask.csdn.net/questions/7566632?spm1005.2025.3001.5141int n 0, a 0, b 0, p 1;std::cin >> n;while (n--){std::cin >> a >> b;while (a<b){if (a %…

安全生产责任制考核方案与风险评估

安全生产责任制考核方案旨在通过有效落实国家安全生产法律法规&#xff0c;确保煤矿及相关单位的安全管理机制建立与运行&#xff0c;减少生产安全事故的发生。方案强调通过定期的量化考核和系统化评估&#xff0c;确保安全生产责任的有效落实。考核涉及集团公司各单位及相关人…

强制重装及验证onnxruntime-gpu是否正确工作

#工作记录 我们经常会遇到明明安装了onnxruntime-gpu或onnxruntime后&#xff0c;无法正常使用的情况。 一、强制重新安装 onnxruntime-gpu 及其依赖 # 强制重新安装 onnxruntime-gpu 及其依赖 pip install --force-reinstall --no-cache-dir onnxruntime-gpu1.18.0 --extra…

设计模式 --- 外观模式

外观模式是一种结构型设计模式&#xff0c;为复杂子系统提供​​统一的高层接口​​&#xff0c;通过定义一个外观类来​​简化客户端与子系统的交互​​&#xff0c;降低系统耦合度。这种模式隐藏了子系统的复杂性&#xff0c;将客户端与子系统的实现细节隔离开来&#xff0c;…

用python脚本怎么实现:把一个文件夹里面.png文件没有固定名称,复制到另外一个文件夹按顺序命名?

环境&#xff1a; python3.10 Win10 问题描述&#xff1a; 用python脚本怎么实现&#xff1a;怎么把一个文件夹里面.png文件没有固定名称&#xff0c;复制到另外一个文件夹按顺序命名&#xff1f; 解决方案&#xff1a; 1.新建一个脚本文件&#xff0c;内容如下&#xff1…

山东大学软件学院创新项目实训开发日志(20)之中医知识问答自动生成对话标题bug修改

在原代码中存在一个bug&#xff1a;当前对话的标题不是现有对话的用户的第一段的前几个字&#xff0c;而是历史对话的第一段的前几个字。 这是生成标题的逻辑出了错误&#xff1a; 当改成size()-1即可

ZYNQ笔记(十):XADC (PS XDAC 接口)

版本&#xff1a;Vivado2020.2&#xff08;Vitis&#xff09; 任务&#xff1a;通过 PS XADC 接口读取XADC测量的芯片温度、供电电压&#xff0c;并通过串口打印出来 目录 一、介绍 二、硬件设计 三、软件设计 四、效果 一、介绍 XADC&#xff08;Xilinx Analog-to-Digital…

【C++】多态 - 从虚函数到动态绑定的核心原理

&#x1f4cc; 个人主页&#xff1a; 孙同学_ &#x1f527; 文章专栏&#xff1a;C &#x1f4a1; 关注我&#xff0c;分享经验&#xff0c;助你少走弯路 文章目录 1. 多态的概念2. 多态的定义及实现2.1 多态的构成条件2.1.1实现多态还有两个必须重要条件&#xff1a;2.1.2 虚…

免费图片软件,可矫正倾斜、调整去底效果

软件介绍 有个超棒的软件要给大家介绍一下哦&#xff0c;它就是——ImgTool&#xff0c;能实现图片漂白去底的功能&#xff0c;而且重点是&#xff0c;它是完全免费使用的呢&#xff0c;功能超强大&#xff01; 软件特点及使用便捷性 这软件是绿色版本的哟&#xff0c;就像一…

Kubernetes(k8s)学习笔记(二)--k8s 集群安装

1、kubeadm kubeadm 是官方社区推出的一个用于快速部署 kubernetes 集群的工具。这个工具能通过两条指令完成一个 kubernetes 集群的部署&#xff1a; 1.1 创建一个 Master 节点$ kubeadm init 1.2 将一个 Node 节点加入到当前集群中$ kubeadm join <Master 节点的 IP 和…

【论文阅读笔记】模型的相似性

文章目录 The Platonic Representation Hypothesis概述表征收敛的依据表征收敛的原因实验依据未来发展的局限性 Similarity of Neural Network Representations Revisited概述问题背景相似性度量s的性质可逆线性变换不变性正交变换不变性各向同性缩放不变性典型度量满足的性质 …

扣子智能体1:创建Agent与写好提示词

文章目录 Agent是什么使用扣子创建智能体写好提示词生成故事发布Agent 最近学了很久多agent协同、编排工作流等与agent有关的内容&#xff0c;这里用一系列博客&#xff0c;把这些操作都一步一个脚印的记录下来。 这里我们以一个Agent为例&#xff1a;睡前灵异小故事 Agent是…

Spring源码中关于抽象方法且是个空实现这样设计的思考

Spring源码抽象方法且空实现设计思想 在Spring源码中onRefresh()就是一个抽象方法且空实现&#xff0c;而refreshBeanFactory()方法就是一个抽象方法。 那么Spring源码中onRefresh方法定义了一个抽象方法且是个空实现&#xff0c;为什么这样设置&#xff0c;好处是什么。为…

【Bluedroid】蓝牙 HID 设备信息加载与注册机制及配置缓存系统源码解析

本篇解析Android蓝牙子系统加载配对HID设备的核心流程&#xff0c;通过btif_storage_load_bonded_hid_info实现从NVRAM读取设备属性、验证绑定状态、构造描述符并注册到BTA_HH模块。重点剖析基于ConfigCache的三层存储架构&#xff08;全局配置/持久设备/临时设备&#xff09;&…

字节头条golang二面

docker和云服务的区别 首先明确Docker的核心功能是容器化&#xff0c;它通过容器技术将应用程序及其依赖项打包在一起&#xff0c;确保应用在不同环境中能够一致地运行。而云服务则是由第三方提供商通过互联网提供的计算资源&#xff0c;例如计算能力、存储、数据库等。云服务…