【数据库】事务
目录
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表示自动提交开启
可以通过以下语句设置事务为自动或手动提交:

注意:
- 只要使用start transaction或begin开启事务,必须通过commit提交才会持久化,与是否设置set autocommit无关
- 手动提交模式下,不用显示开启事务,执行修改操作后,提交或回滚事务时直接使用commit或rollback
- 已提交的事务不能回滚
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';
相关文章:
【数据库】事务
目录 1. 什么是事务? 2. 事务的ACID特性 3. 为什么使用事务? 4. 如何使用事务 4.1 查看支持事务的存储引擎 4.2 语法 4.3 保存点 4.4 自动/手动提交事务 5. 事物的隔离性和隔离级别 5.1 什么是隔离性 5.2 隔离级别 5.3 查看和设置隔离级别 1…...
使用Redis实现实时排行榜
为了实现一个实时排行榜系统,我们可以使用Redis的有序集合(ZSet),其底层通常是使用跳跃表实现的。有序集合允许我们按照分数(score)对成员(member)进行排序,因此非常适合…...
QML中的3D功能--入门开发
Qt Quick 提供了强大的 3D 功能支持,主要通过 Qt 3D 模块实现。以下是 QML 中开发 3D 应用的全面指南。 1. 基本配置 环境要求 Qt 5.10 或更高版本(推荐 Qt 6.x) 启用 Qt 3D 模块 支持 OpenGL 的硬件 项目配置 在 .pro 文件中添加: QT += 3dcore 3drender 3dinput 3dex…...
6. 字符串
1.反转字符串 2.替换数字 3.反转字符串中的单词 4.KMP算法 5.重复的子字符串(看具体证明) 太6了(真不是人做的)...
000.初识 dyld
dyld(Dynamic Link Editor) 是 Apple 操作系统的动态加载器/链接器。 在 iOS 或 iPadOS 启动一个 Mach‑O 可执行文件时,dyld 会: 解析可执行文件头,确认 CPU 架构、地址空间布局随机化(ASLR)参…...
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编程怎么写,紧急求解-编程语言-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 %…...
安全生产责任制考核方案与风险评估
安全生产责任制考核方案旨在通过有效落实国家安全生产法律法规,确保煤矿及相关单位的安全管理机制建立与运行,减少生产安全事故的发生。方案强调通过定期的量化考核和系统化评估,确保安全生产责任的有效落实。考核涉及集团公司各单位及相关人…...
Transformers是一种基于自注意力机制的神经网络模型
概述与发展历程 背景介绍 Transformers是一种基于自注意力机制的神经网络模型,最早由Google团队在2017年的论文《Attention Is All You Need》中提出。该模型旨在解决传统循环神经网络(RNNs)在处理长距离依赖关系时的低效性问题,…...
32-工艺品商城小程序
技术: 基于 B/S 架构 SpringBootMySQLvueelementuiuniapp 环境: Idea mysql maven jdk1.8 node 可修改为其他类型商城 用户端功能 1.系统首页展示轮播图及工艺品列表 2.分类模块:展示产品的分类类型 3.购物车:进行商品多选结算 或者批量管理操作 4.…...
深度解析微前端架构设计:从monorepo工程化设计到最佳实践
一、项目架构概览:微前端与传统架构的融合创新 在企业级前端工程中,微前端架构通过「分治思想」解决了单体应用臃肿、技术栈割裂、团队协作低效等问题。本项目采用 主应用(基座) 子应用集群 独立服务 的立体化架构,支…...
强制重装及验证onnxruntime-gpu是否正确工作
#工作记录 我们经常会遇到明明安装了onnxruntime-gpu或onnxruntime后,无法正常使用的情况。 一、强制重新安装 onnxruntime-gpu 及其依赖 # 强制重新安装 onnxruntime-gpu 及其依赖 pip install --force-reinstall --no-cache-dir onnxruntime-gpu1.18.0 --extra…...
设计模式 --- 外观模式
外观模式是一种结构型设计模式,为复杂子系统提供统一的高层接口,通过定义一个外观类来简化客户端与子系统的交互,降低系统耦合度。这种模式隐藏了子系统的复杂性,将客户端与子系统的实现细节隔离开来,…...
OverlayFS 简介与最简单 Demo
OverlayFS 是什么 OverlayFS 是一种 Linux 文件系统,允许将多个目录(称为“层”)叠加在一起,形成一个统一的视图。它广泛用于容器技术(如 Docker),用于实现镜像层和容器写时复制(Co…...
Python爬虫实战:获取B站查询数据
一、引言 1.1 研究背景 随着互联网的迅猛发展,视频分享平台积累了海量的数据资源。以 B 站为例,其丰富的视频内容和活跃的用户群体蕴含着巨大的价值。对 B 站搜索数据进行爬取和分析,有助于洞察用户兴趣、市场趋势以及内容创作方向,为市场调研、用户行为分析和内容推荐系…...
用python脚本怎么实现:把一个文件夹里面.png文件没有固定名称,复制到另外一个文件夹按顺序命名?
环境: python3.10 Win10 问题描述: 用python脚本怎么实现:怎么把一个文件夹里面.png文件没有固定名称,复制到另外一个文件夹按顺序命名? 解决方案: 1.新建一个脚本文件,内容如下࿱…...
山东大学软件学院创新项目实训开发日志(20)之中医知识问答自动生成对话标题bug修改
在原代码中存在一个bug:当前对话的标题不是现有对话的用户的第一段的前几个字,而是历史对话的第一段的前几个字。 这是生成标题的逻辑出了错误: 当改成size()-1即可...
ZYNQ笔记(十):XADC (PS XDAC 接口)
版本:Vivado2020.2(Vitis) 任务:通过 PS XADC 接口读取XADC测量的芯片温度、供电电压,并通过串口打印出来 目录 一、介绍 二、硬件设计 三、软件设计 四、效果 一、介绍 XADC(Xilinx Analog-to-Digital…...
适配器模式在Java开发中的应用
适配器模式(Adapter Pattern)是设计模式中的一种结构型模式,它允许将一个类的接口转换成客户端所期望的另一个接口。通过这种方式,原本因接口不兼容而无法协同工作的类能够一起工作。适配器模式在Java开发中非常常见,尤…...
【Rust 精进之路之第15篇-枚举 Enum】定义、变体与数据关联:表达多种可能性
系列: Rust 精进之路:构建可靠、高效软件的底层逻辑 作者: 码觉客 发布日期: 2025年4月20日 引言:当值拥有“选项”——超越结构体的表达力 在上一篇【结构体 Struct】中,我们学习了如何使用结构体将多个相关的数据字段组合成一个有意义的整体。结构体非常适合表示那些…...
【C++】多态 - 从虚函数到动态绑定的核心原理
📌 个人主页: 孙同学_ 🔧 文章专栏:C 💡 关注我,分享经验,助你少走弯路 文章目录 1. 多态的概念2. 多态的定义及实现2.1 多态的构成条件2.1.1实现多态还有两个必须重要条件:2.1.2 虚…...
免费图片软件,可矫正倾斜、调整去底效果
软件介绍 有个超棒的软件要给大家介绍一下哦,它就是——ImgTool,能实现图片漂白去底的功能,而且重点是,它是完全免费使用的呢,功能超强大! 软件特点及使用便捷性 这软件是绿色版本的哟,就像一…...
Kubernetes(k8s)学习笔记(二)--k8s 集群安装
1、kubeadm kubeadm 是官方社区推出的一个用于快速部署 kubernetes 集群的工具。这个工具能通过两条指令完成一个 kubernetes 集群的部署: 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有关的内容,这里用一系列博客,把这些操作都一步一个脚印的记录下来。 这里我们以一个Agent为例:睡前灵异小故事 Agent是…...
Spring源码中关于抽象方法且是个空实现这样设计的思考
Spring源码抽象方法且空实现设计思想 在Spring源码中onRefresh()就是一个抽象方法且空实现,而refreshBeanFactory()方法就是一个抽象方法。 那么Spring源码中onRefresh方法定义了一个抽象方法且是个空实现,为什么这样设置,好处是什么。为…...
正则表达式(Regular Expressions)基本语法
无论前端还是后端开发过程中都不可避免的会使用到正则表达式,在对于程序的优化中,也起到了很重要的作用,可以减少非必要的接口和网络交互,减少服务器压力。 正则表达式(Regular Expressions,简称 regex 或 regexp)是一种强大的文本处理工具,用于匹配字符串中的特定模式…...
提示词设计:动态提示词 标准提示词
提示词设计:动态提示词 标准提示词 研究背景:随着人工智能与司法结合的推进以及裁判文书公开数量增多,司法摘要任务愈发重要。传统司法摘要方法生成质量有待提升,大语言模型虽有优势,但处理裁判文书时存在摘要结构信息缺失、与原文不一致等问题。研究方法 DPCM方法:分为大…...
