MySQL之基础事务
目录
引言:
什么是事务?
事务和锁
mysql数据库控制台事务的几个重要操作指令(transaction.sql)
1、事物操作示意图:
2.事务的隔离级别
四种隔离级别:
总结一下隔离指令
1. 查看当前隔离级别
2.设置隔离级别
(1) 设置当前会话(临时生效)
(2) 设置全局(需管理员权限)
3.修改默认级别
3.ACID 特性
1.原子性 (Atomicity)
2. 一致性 (Consistency)
3. 隔离性 (Isolation)
4. 持久性 (Durability)
类别 | SQL 语句示例 | 作用 |
---|---|---|
DML | INSERT , UPDATE , DELETE | 操作数据(增删改查) |
DDL | CREATE , ALTER , DROP | 定义数据库结构(如表、索引、视图等) |
DCL | GRANT , REVOKE | 控制访问权限 |
TCL | COMMIT , ROLLBACK | 管理事务 |
引言:
-
什么是事务?
事务就是用于保证数据的一致性,她由一组相关的dml语句组成,该组的dml语句要么全部成功,要么全部失败。如:转账就必须保证事务的一致性。
比如我这里有两个指令:
-- 转账人
update balance set balance=balance-100 where id = 1--收款人
update balance set balance=balance+100 where id = 2
如何保证两条语句同时执行成功?
-
事务和锁
当执行操作(dml语句) ,mysql会在表上加锁,防止其他用户修改表的数据,这对用户来说是非常重要的
-
mysql数据库控制台事务的几个重要操作指令(transaction.sql)
1.start transaction --开启一个事务
2.savepoint 自定义保存点的名称 --设置保存点
3.rollback ro 自定义保存点名称 --回退事务
4.rollback --回退全部事务,回到事务开始的时候
5.commit --提交事务,结束事务,删除该事务的所有保存点,删除锁,不能回退,数据生效,其他会话[其他连接]可以查看生效的新数据
1、事物操作示意图:
类似于git的回滚操作
用户a在进行事务操作的时候,用户b在数据库是查看不到一部分数据的变化的,必须要等到用户a提交才行,这叫事务隔离,至于是看得见哪一部分的数据得取决于用的隔离级别
还有一种开启事务的方式:set autocommit = off
-- 关闭当前会话的自动提交(影响后续所有操作)
SET autocommit = 0;
INSERT INTO orders (product_id) VALUES (101);
-- 必须显式提交
COMMIT;
-- 恢复自动提交(否则后续操作仍需要手动提交)
SET autocommit = 1;
2.事务的隔离级别
1.多个连接开启各自事务操作数据库中的数据时,数据库系统要负责隔离操作,以保证连接在获取数据的准确性
2.如果不考虑隔离性,会导致:脏读、不可重复读、幻读
脏读:当应一个事务读取另外一个事务尚未提交的修改时,产生脏读。就是也可能别人回滚了或者放弃提交了,但是你读到了。
不可重复读:同一个查询在同一个事务中多次进行,由于其他用户提交的事务所做的修改或者删除,每次返回不同的结果集,此时发生不可重复读
幻读:同一个查询在同一个事务中多次进行,由于其他用户提交事务所作的插入操作,每次返回不同的结果集
四种隔离级别:
1.读未提交 read uncommitted
2.读已提交 read committed
3.可重复读 repeatable read
4.可串行化 serializable
测试一下功能:
打开两个操作台a和b
指令1:查询当前mysql的隔离级别
select @@tx_isolation;
或者
SELECT @@transaction_isolation;
会得到一个可重复读的隔离级别
指令2:修改一下这个用户a的隔离级别为读未提交
set session transaction isolation level read uncommitted;
设置成功
我们来对比一下:
此时用户a执行一个语句,还没有commot,但是用户b也能看见,这就是脏读
其他情况也是类似,可以自行下去动手查看
那这些脏读、不可重复读、幻读我们都理解了,那锁呢?
当用户a开启事务之后插入更新了一些数据
那么用户b持有可串行化的隔离级别,是什么情况:
答案是按回车之后被卡住,这个用户b会一直等待连接到这个数据库
这时候就有两种情况:
1.超时:
2.用户a提交了,用户b才出现结果
总结一下隔离指令
1. 查看当前隔离级别
-- 查看当前会话的隔离级别
SELECT @@SESSION.transaction_isolation;-- 查看全局隔离级别
SELECT @@GLOBAL.transaction_isolation;
2.设置隔离级别
(1) 设置当前会话(临时生效)
SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED; -- 读未提交
SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED; -- 读已提交
SET SESSION TRANSACTION ISOLATION LEVEL REPEATABLE READ; -- 可重复读(默认)
SET SESSION TRANSACTION ISOLATION LEVEL SERIALIZABLE; -- 串行化
(2) 设置全局(需管理员权限)
SET GLOBAL TRANSACTION ISOLATION LEVEL READ COMMITTED; -- 修改全局配置
FLUSH PRIVILEGES; -- 刷新权限(可选)
3.修改默认级别
3.ACID 特性
原子性 (Atomicity) → 确保操作完整性
一致性 (Consistency) → 确保数据有效性
隔离性 (Isolation) → 确保并发可控性
持久性 (Durability) → 确保结果永久性
1.原子性 (Atomicity)
- 定义:事务是最小的工作单元,不可再分割。
- 核心原则:事务中的操作要么全部成功,要么全部失败回滚。
- 示例:银行转账中,扣款和收款必须同时成功或同时失败。
2. 一致性 (Consistency)
- 定义:事务执行前后,数据库必须从一个一致性状态变换到另一个一致性状态。
- 核心原则:数据完整性约束(如主键、外键、唯一约束)不会被破坏。
- 示例:转账前后,双方账户总额应保持不变。
3. 隔离性 (Isolation)
- 定义:多个并发事务之间相互隔离,一个事务的操作不应影响其他事务。
- 核心原则:通过隔离级别(如
READ COMMITTED
)控制事务间的可见性。 - 问题规避:避免脏读、不可重复读、幻读等问题。
4. 持久性 (Durability)
- 定义:事务一旦提交,对数据的修改就是永久性的。
- 核心原则:即使系统崩溃,数据也能通过日志恢复。
- 实现机制:依赖事务日志(如 InnoDB 的 redo log)。
相关文章:

MySQL之基础事务
目录 引言: 什么是事务? 事务和锁 mysql数据库控制台事务的几个重要操作指令(transaction.sql) 1、事物操作示意图: 2.事务的隔离级别 四种隔离级别: 总结一下隔离指令 1. 查看当前隔离级别 …...
uniapp设置 overflow:auto;右边不显示滚动条的问题
设置了overflow:auto;或者其它overflow的属性不显示滚动条是因为在uniapp中默认隐藏了滚动条 解决方法: //强制显示滚动条 ::-webkit-scrollbar {width: 8px !important;background: #ccc !important;display: block !important;}//设置滚动条颜色.cu-…...
数据库基础复习笔记
数据库 相关概念 名称全称检查数据库存储数据的仓库,数据是有组织的进行存储DataBase(DB)数据库管理系统操作和管理数据库的大型软件DataBase Management System(DBMS)SQL操作关系型数据库的编程语言,定义了一套操作关系型数据库…...

MySQL基础关键_013_常用 DBA 命令
目 录 一、MySQL 用户信息存储位置 二、新建用户 1.创建本地用户 2.创建外网用户 三、用户授权 1.说明 2.实例 四、撤销授权 五、修改用户密码 六、修改用户名、主机名/IP地址 七、删除用户 八、数据备份 1.导出数据 2.导入数据 (1)方式…...
爬虫请求频率应控制在多少合适?
爬虫请求频率的控制是一个非常重要的问题,它不仅关系到爬虫的效率,还涉及到对目标网站服务器的影响以及避免被封禁的风险。合理的请求频率需要根据多个因素来综合考虑,以下是一些具体的指导原则和建议: 一、目标网站的政策 查看网…...
探秘网络邮差:FTP、Telnet、SMTP、NFS、SNMP介绍
引言:谁是网络世界的“邮差”? 想象一下,你正在网上冲浪——发送一封邮件、上传一份文件、远程登录服务器,甚至只是打开一个网页。这些看似简单的操作背后,其实有一群默默无闻的“邮差”在辛勤工作。它们就是应用层协…...

java基础:异常体系
目录 一、java异常体系介绍二、异常1、运行时异常2、非运行时异常 三、错误四、异常的处理方式1、方式1:throws声明抛出异常1.1、throws关键字1.2、throw关键字 2、方式2:try-catch-finally 一、java异常体系介绍 异常体系图如下: Throwable…...
CSS Grid布局:从入门到实战
CSS Grid布局:从入门到实战 一、初识Grid布局 还在为网页布局发愁吗?Flexbox虽然好用,但当遇到复杂布局时,CSS Grid才是真正的王者。Grid布局是CSS中最强大的二维布局系统,它就像一张无形的网格纸,让我们…...

记录算法笔记(20025.5.14)对称二叉树
给你一个二叉树的根节点 root , 检查它是否轴对称。 示例 1: 输入:root [1,2,2,3,4,4,3] 输出:true 示例 2: 输入:root [1,2,2,null,3,null,3] 输出:false 提示: 树中节点数目…...

QT Creator配置Kit
0、背景:qt5.12.12vs2022 记得先增加vs2017编译器 一、症状: 你是否有以下症状? 1、用qt新建的工程,用qmake,可惜能看见的只有一个pro文件? 2、安装QT Creator后,使用MSVC编译显示no c com…...

JVM 与云原生的完美融合:引领技术潮流
最近佳作推荐: Java 大厂面试题 – 揭秘 JVM 底层原理:那些令人疯狂的技术真相(New) Java 大厂面试题 – JVM 性能优化终极指南:从入门到精通的技术盛宴(New) Java 大厂面试题 – JVM 深度剖析&…...
Ubuntu24.04编译ORB_SLAM的一系列报错解决
Ubuntu24.04编译ORB_SLAM的一系列报错解决 decay_t报错 报错信息:error: ‘decay_t’ is not a member of ‘std’;did you mean ‘decay’ 将CMakeLists.txt中第17行的c标准修改为c14即可: 修改前: CHECK_CXX_COMPILER_FLAG…...

为何大模型都使用decoder-only?
第一章 架构之争的历史脉络 1.1 从双向到单向的革命 2017年,BERT的横空出世让双向注意力机制成为NLP领域的“武林盟主”。通过Masked Language Modeling(MLM),BERT在阅读理解、情感分析等任务中展现出惊人的表现,但它…...
《Effective Python》第2章 字符串和切片操作——Python 字符串格式化的现代选择f-strings
引言 本篇博客基于学习《Effective Python》第三版 Chapter 2: Strings and Slicing 的 Item 11 “Prefer Interpolated F-Strings Over C-style Format Strings and str.format” 的总结与延伸。 字符串格式化是 Python 编程中的常见操作,用于动态生成可读性高的…...

企业报表平台如何实现降本增效
一、你的企业是否正被这些问题拖累? 财务还在手动汇总各门店的Excel销售数据;市场部总抱怨“客户分析全靠拍脑袋”;仓库突然发现爆款断货,但上周的报表显示库存充足…… 这些场景你是否熟悉?数据散落在ERP、E…...

Ollama+OpenWebUI+docker完整版部署,附带软件下载链接,配置+中文汉化+docker源,适合内网部署,可以局域网使用
前言: 因为想到有些环境可能没法使用外网的大模型,所以可能需要内网部署,看了一下ollama适合小型的部署,所以就尝试了一下,觉得docker稍微简单一点,就做这个教程的,本文中重要的内容都会给下载…...
git push 报错:send-pack: unexpected disconnect while reading sideband packet
背景 新建了一个仓库,第一次push 代码文件,文件中有一个依赖的jar,有80MB,结果push的时候报错。 错误信息 error: RPC failed; HTTP 500 curl 22 The requested URL returned error: 500 send-pack: unexpected disconnect whi…...
考研英一真题学习笔记 2018年
2018 年全国硕士研究生招生考试 英语 (科目代码:201) Section Ⅰ Use of English Directions: Read the following text. Choose the best word(s) for each numbered blank and mark A, B, C or D on the ANSWER SHEET. (10 points) Trust i…...

ultralytics中tasks.py---parse_model函数解析
一、根据scale获取对应的深度、宽度和最大通道数 具体例如yaml文件内容如下: depth=0.33,那么重复的模块例如C2f原本重复次数是3,6,6,3,那么T对应的模型重复次数就是三分之一即1,1,2,1次。这个在后面定义的: width=0.25,max_channels=1024 原本c2=64,但经过make_div…...
Java知识框架
一、Java 基础语法 1. 基础语法 数据类型 基本类型:int, double, boolean, char 等 引用类型:String, 数组, 对象 变量与常量 final 关键字 作用域(局部变量、成员变量) 运算符 算术、逻辑、位运算 三元运算符 ? : 控制…...

2024年业绩增速大幅回退,泸州老窖未能“重回前三”
撰稿|行星 来源|贝多财经 回望过去的2024年,受制于购买力与消费需求的持续疲软,白酒行业的发展面临诸多复杂性与不确定性,“量价齐跌”犹如笼罩在各大企业头顶的一片阴云。 正如巴菲特所言:“当潮水退去时,才知道谁在…...

院校机试刷题第二天:1479 01字符串、1701非素数个数
一、1479 01字符串 1.题目描述 2.解题思路 方法一:暴力法 模拟过程,列出几个数据来a[1]1, a[2]2, a[3]3, a[4]5以此类推,这就是斐波那契数列,每一项都等于前两项之和,确定好a[1], a[2]即可。 方法二:动…...
【Vue.js 的核心魅力:深入理解声明式渲染】
Vue.js 的核心魅力:深入理解声明式渲染 在现代前端框架的浪潮中,Vue.js 以其轻量、易学、高效的特点赢得了广大开发者的青睐。其核心魅力之一,便是其优雅的**声明式渲染 (Declarative Rendering)**机制。理解声明式渲染不仅能帮助我们更好地…...

制作一款打飞机游戏48:敌人转向
射击功能 有一个重要的功能我们还没实现,那就是射击。目前,敌人还不能射击,这显然是不行的。因此,我们决定添加一个射击命令,暂时用一个显示圆圈的方式来表示射击动作。 编程语言的调试 有趣的是,我们创…...
鸿蒙OSUniApp打造多功能图表展示组件 #三方框架 #Uniapp
使用UniApp打造多功能图表展示组件 在当前移动应用开发领域,数据可视化已成为不可或缺的一部分。无论是展示销售数据、用户增长趋势还是其他业务指标,一个优秀的图表组件都能有效提升用户体验。UniApp作为一款跨平台开发框架,如何在其中实现…...
Chrome浏览器实验性API computePressure的隐私保护机制如何绕过?
一、computePressure API 设计原理与隐私保护机制 1.1 API 设计目标 computePressure是W3C提出的系统状态监控API,旨在: • 提供系统资源状态的抽象指标(非精确值) • 防止通过高精度时序攻击获取用户指纹 • 平衡开发者需求与用户隐私保护 1.2 隐私保护实现方式 // 典…...

RK3588 串行解串板,支持8路GMSL相机
RK3588 支持的 GMSL 相机接入数量取决于所使用的解串板型号及配置方案: xcDeserializer3.0 解串板 可接入最多 8 路 2M GMSL2 相机1。 xcDeserializer4.0 解串板 支持 4 路 2M GMSL2 相机1。 边缘计算盒解决方案 部分商用方案可实现 4 或 8…...

OracleLinux7.9-ssh问题
有套rac环境,db1主机无法ssh db1和db1-priv,可以ssh登录 db2和db2-priv [rootdb1 ~]# ssh db1 ^C [rootdb1 ~]# ssh db2 Last login: Wed May 14 18:25:19 2025 from db2 [rootdb2 ~]# ssh db2 Last login: Wed May 14 18:25:35 2025 from db1 [rootdb2…...

手机换IP真的有用吗?可以干什么?
在当今数字化时代,网络安全和个人隐私保护日益受到重视。手机作为我们日常生活中不可或缺的工具,其网络活动痕迹往往通过IP地址被记录和追踪。那么,手机换IP真的有用吗?它能为我们带来哪些实际好处?本文将为你一一解答…...
提示词设计模板(基于最佳实践)
1. 任务清晰化 模糊指令 ➜ 明确指令 ❌ "写一篇关于环保的文章" ✅ *"列出5种城市环保措施,并分别说明其对减少碳排放的影响(要求:数据支持案例)"* 2. 任务步骤化 案例:策划线上营销活动 1.…...