MySQL之基础事务

目录

引言:

什么是事务?

事务和锁

mysql数据库控制台事务的几个重要操作指令(transaction.sql)

1、事物操作示意图:

2.事务的隔离级别 

四种隔离级别:

总结一下隔离指令

1. 查看当前隔离级别​​

2.设置隔离级别​​

​​(1) 设置当前会话(临时生效)

​​(2) 设置全局(需管理员权限)​​

3.修改默认级别

3.ACID 特性

1.原子性 (Atomicity)​​

​​2. 一致性 (Consistency)​​

​​3. 隔离性 (Isolation)​​

​​4. 持久性 (Durability)​​


​类别​​SQL 语句示例​​作用​
​DML​INSERTUPDATEDELETE​操作数据​​(增删改查)
​DDL​CREATEALTERDROP​定义数据库结构​​(如表、索引、视图等)
​DCL​GRANTREVOKE​控制访问权限​
​TCL​COMMITROLLBACK​管理事务​

引言:

  • 什么是事务?

事务就是用于保证数据的一致性,她由一组相关的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)。

 

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

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

相关文章

VS Code 重磅更新:全新 MCP 服务器发现中心上线

目前各种 MCP 客户端层出不穷,但是安装 MCP 服务却格外繁琐,尤其 VS Code 中无界面化的 MCP 服务配置方式,效率较低。 Copilot MCP 是一个 VS Code 插件,在今天发布的新版本中,插件支持了自动发现与安装开源 MCP 服务…

智能家居“心脏“升级战:GD25Q127CSIG国产芯片如何重构家庭物联生态

在智能家居设备出货量突破10亿台的2023年,家庭网关正经历着前所未有的技术革新。作为连接云端与终端设备的中枢神经,智能网关的存储芯片选择直接决定着整个智能生态系统的运行效率。在这场技术升级浪潮中,兆易创新GD25Q127CSIG串行闪存芯片主…

R语言机器学习算法实战系列(二十五)随机森林算法多标签分组分类器及模型可解释性

禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍教程内容加载必要的R包(带详细注释)1. 加载数据2. 数据分割(按Species分层抽样)3. 数据预处理配方4. 创建随机森林模型(多分类)5. 创建工作流6. 设置交叉验证和参数调优7. 参…

速查 Linux 常用指令 II

目录 一、网络管理命令1. 查看和配置网络设备:ifconfig1)重启网络命令2)重启网卡命令 2. 查看与设置路由:route3. 追踪网络路由:traceroute4. 查看端口信息和使用情况1)netstat 命令2)lsof 命令…

关于github使用总结

文章目录 一、本地使用git(一)创建一个新的本地Git库首先在本地创建一个新的git仓库然后进行一次初始提交提交过后就可以查看提交记录 (二)在本地仓库进行版本恢复先执行 git log 查看项目提交历史使用 git checkout 恢复版本 二、…

【Python】Python 单例模式 8 大核心应用场景深度解析(2025 新版)

单例模式(Singleton Pattern)作为一种经典的设计模式,始终保持着重要的工程价值。 本文着重于单例模式的主要核心应用场景。 至于实现方法, 晚些时候发出。 一、配置管理器 全局配置信息管理是单例模式最典型的应用场景。通过单…

计算机网络网络层(下)

一、互联的路由选择协议(网络层控制层面内容) (一)有关路由选择协议的几个概念 1.理想的路由算法 (1)理想路由算法应具备的特点:算法必须正确和完整的,算法在计算上应简单&#x…

云存储桶的“公开陷阱”|渗透测试中如何利用与防御配置错误的存储服务

引言 云存储服务(如AWS S3、阿里云OSS、Google Cloud Storage)因便捷性被企业广泛使用,但权限配置错误却成为近年来数据泄露的重灾区。 攻击者无需复杂漏洞,仅需一个公开链接即可下载敏感数据。本文将深入解析这类漏洞的渗透…

BitMart合约交易体验 BitMart滑点全赔的底层逻辑

美国新泽西州泽西市,2025年5月13日 – BitMart,全球领先的数字资产交易平台,推出了其开创性的滑点保护计划,旨在解决加密市场中最具挑战性且常常被忽视的风险之一:滑点。该计划为交易者提供了在 USDT 保证金永续合约交…

高海拔和远距离的人员识别:面部、体型和步态的融合

大家读完就觉得有帮助记得关注和点赞!!! 摘要 我们解决了在无约束环境中进行全身人体识别的问题。这个问题出现在诸如IARPA高空和远距离生物识别与身份识别(BRIAR)计划等监视场景中,其中生物识别数据是在长…

Docker 常见问题及其解决方案

一、安装与启动问题 1.1 安装失败 在不同操作系统上安装 Docker 时,可能会出现安装失败的情况。例如,在 Ubuntu 系统中,执行安装命令后提示依赖缺失。这通常是因为软件源配置不正确或系统缺少必要的依赖包。 解决方案: 确保系统…

影响力最小化

这里写目录标题 影响力最大化**创新点**参数设置 影响力最小化传播模型该文献和Budak的有什么不同呢a Linear Threshold model with One Direction state Transition (LT1DT)具体模型 影响力最大化 以INFORMS Journal on Computing为例《The Impact of Passive Social Media Vi…

【IDEA】注释配置

1. IDEA注释调整,去掉默认在第一列显示 修改为如下: 2. IDEA中修改代码中的注释颜色

一文了解 HTTP Content-Type:从基础到实战

一文了解 HTTP Content-Type:从基础到实战 在 Web 开发中,HTTP 请求头中的 Content-Type 是一个看似简单却至关重要的概念。它决定了浏览器和服务器如何解析和处理传输的数据。本文将带你全面掌握 Content-Type 的核心知识,涵盖常见类型、应…

兔子队列?RabbitMQ详解(1)

引入 首先先介绍一下什么是 RabbitMQ 的意思:Rabbit 是一个公司的名称,MQ 是 message queue (消息队列)的缩写,而 RabbitMQ 是 Rabbit 企业下的一个消息队列产品,是一个采用Erlang语言实现AMQP(Advanced Message Queuing Protocol,高级消息队列协议)的消息中间件,它最初…

某智能家电龙头,社招 校招全面应用 AI 面试的创新实践

某智能家电龙头在竞争中凭借创新能力和高品质服务稳居市场前列,为更好地赋能业务,集团招聘总监着力构建数字化招聘流程,率先引入 AI 面试实现招聘智能化升级,减轻 HR 负担、提升效率,优化候选人体验,达成双…

STM32 实时时钟(RTC)详解

一、RTC 简介 RTC(Real Time Clock)即实时时钟,本质上是一个 32 位的秒级计数器: 最大计数值为 4294967295 秒,约合 136 年: 复制编辑 4294967295 / 60 / 60 / 24 / 365 ≈ 136 年 RTC 初始化时&#x…

《AI驱动的智能推荐系统:原理、应用与未来》

一、引言 在当今信息爆炸的时代,用户面临着海量的信息选择,从购物平台上的商品推荐到流媒体服务中的影视推荐,智能推荐系统已经成为我们日常生活中不可或缺的一部分。AI驱动的智能推荐系统通过分析用户的行为和偏好,为用户提供个性…

Django + Celery 打造企业级大模型异步任务管理平台 —— 从需求到完整实践(含全模板源码)

如需完整工程文件(含所有模板),可回复获取详细模板代码。 面向人群:自动化测试工程师、企业中后台开发人员、希望提升效率的 AI 业务从业者 核心收获:掌握 Django 三表关系设计、Celery 异步任务实践、基础 Web 交互与前后端分离思路,源码可直接落地,方便二次扩展 一、系…

创建对象

虽然Object构造函数或对象字面量可以方便地创建对象,但这些方式也有明显不足: 创建具有同样接口的多个对象需要重复编写很多代码 1.工厂模式 工厂模式是一种众所周知的设计模式,广泛应用于软件工程领域,用于抽象创建特定对象的过程 function createPerson(name,age){let…