MySQL事务管理(一)

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: MySQL事务管理

一、事务概念

事务由一条或多条SQL语句组成,这些语句在逻辑上存在相关性,共同完成一个任务,事务主要用于处理操作量大,复杂度高的数据。如转账就涉及多条SQL语句,包括查询余额(select)、在当前账户上减去指定金额(update)、在指定账户上加上对应金额(update)等,将多条SQL语句打包便构成了一个事务

MySQL同一时刻可能存在大量事务,若不对这些事务加以控制,在执行时就可能会出现问题。如单个事务内部的某些SQL语句执行失败,或是多个事务同时访问同一份数据导致数据不一致的问题

一个完整的事务并不是简单的SQL集合,事务还需要满足如下四个属性(简称ACID):


原子性(Atomicity,又称不可分割性): 一个事务中的所有操作,要么全部完成,要么全部不完成,不会结束在中间某个环节。事务在执行过程中若发生错误,则会自动回滚到事务开始前的状态,就像这个事务从来没有执行过一样

持久性(Consistency): 事务处理结束后,对数据的修改是永久的,即便系统故障也不会丢失

隔离性(Isolation,又称独立性): 数据库允许多个事务同时访问同一份数据,隔离性可以保证多个事务在并发执行时,不会因为由于交叉执行而导致数据的不一致

一致性(Durability): 在事务开始前和事务结束后,数据库的完整性没有被破坏,这表示写入的资料必须完全符合所有的预设规则,这包含资料的精确度、串联型以及后续数据库可以自发性地完成预定的工作

为什么会出现事务?


事务被MySQL编写者设计出来,本质是为了当应用程序访问数据库的时候,事务能够简化编程模型,不需要用户考虑各种各样的潜在错误和并发问题

若MySQL只单纯的提供数据存储服务,那么用户在访问数据库时就需自行考虑各种潜在问题,包括网络异常、服务器宕机等。因此事务本质是为了应用服务的,而不是伴随着数据库系统天生就有的

二、事务的版本支持

通过show engines可查看数据库引擎

204cf11b06754a99be69ead38c9dfd55.png


Engine: 存储引擎名称

Support: 表示服务器对存储引擎的支持级别,YES支持,NO不支持,DEFAULT表示数据库默认使用的存储引擎,DISABLED表示支持引擎但已将其禁用

Comment: 表示存储引擎的简要说明

Transactions: 表示存储引擎是否支持事务,可以看到仅有InnoDB存储引擎支持事务

XA: 表示存储引擎是否支持XA事务

Savepoints: 表示存储引擎是否支持保存点

三、事务的提交方式

查看事务的提交方式


事务常见的提交方式有两种:自动提交、手动提交


通过show命令查看autocommit全局变量,可以查看事务的自动提交是否被打开(默认打开)

812dd5289ca7437db18969e2750f9061.png


注意:autocommit的值为ON表示自动提交打开;值为OFF表示自动提交关闭,即需使用手动提交的方式进行事务的提交


设置自动提交


通过set命令设置autocommit全局变量的值,可以打开或关闭事务的自动提交


89ee7bf454784312833fb20717bdd236.png

四、事务的相关演示

准备工作


为了演示,将MySQL的隔离级别设置成读未提交,易于观察实验现象

2ae131ebd0484f8487e000feb00b823c.png



设置全局隔离级别后当前会话的隔离级别不会改变,只会影响后续与MySQL新建立的连接,需重启终端才能看到会话的隔离级别改变

d781d3dca665496a80eec92d10a76d7b.png



创建一个银行用户表,表中包含用户的id、姓名和账户余额

a3df23b861f0421babe5581ad916659b.png



4.1 常规操作

启动两个终端,左终端使用begin或start transaction命令启动一个事务,右终端查看银行用户表中的信息


5b8b321f7f88422d8102817545d256f4.png


左终端中的事务向表中插入一条记录,由于将隔离级别设置成了读未提交,因此在左终端中的事务使用commit提交之前,在右终端中就能查看到事务向表中插入的记录

68e639fb933a4c3ca0e8bdea449a5a56.png



左终端的事务使用savepoint命令创建一个保存点,然后继续向表中插入一条记录,此时在右终端中也能看到新插入的记录


a6e60c72dadc4e82b8abe128c12c8453.png


左终端的事务使用rollback命令回滚到保存点s1,右终端在查看表中数据时就看不到第二条记录了


e7b9393a28b54cacae51313cf631442c.png


左终端的事务使用rollback命令回滚到事务最开始,右终端在查看表中数据时就看不到任何记录了


648bc1a4372b45b9b8c2af480cf4efe2.png


注意:


使用 begin或start transaction,可以启动一个事务

使用 savepoint 保存点,可以在事务中创建指定名称的保存点

使用 rollback to 保存点,可以让事务回滚到指定保存点

使用 rollback,可以直接让事务回滚到最开始

使用 commit,可以提交事务,提交事务后就不能回滚了

4.2 原子性

在左终端中启动一个事务,在右终端查看银行用户表中的信息。左终端中的事务向表中插入一条记录,由于隔离级别是读未提交,因此在右终端中能够查询到插入的这条记录

a598f50a20bc4a019da36222bbcc6fac.png



若左终端的事务在提交前因为某些原因与MySQL断开连接,那么MySQL会自动让事务回滚到最开始,右终端中就看不到之前插入的记录了

91bed5118d9849b496584e3eb1d7ae70.png



4.3 持久性

在左终端中启动一个事务,在右终端查看银行用户表中的信息。左终端中的事务向表中插入一条记录,由于隔离级别是读未提交,因此在右终端中能够查询到插入的这条记录


f2efd490b039496999b7629b187ed4ff.png


左终端中的事务在提交后与MySQL断开连接,这时右终端中仍然可以看到之前插入的记录,因为事务提交后数据就持久化


25a20de7ec0540cea590a43435297d0f.png


4.4 单条SQL与事务的关系

通过4.2和4.3的实验不难看出,使用begin或start transaction启动的事务,都必须要使用commit命令手动提交,数据才会被持久化,即使设置了autocommit

实际全局变量autocommit是否被设置影响的是单条SQL语句,InnoDB中的每一条SQL都会默认被封装成事务

autocommit为ON,则单条SQL语句执行后会自动被提交,若为OFF,则SQL语句执行后需要使用commit进行手动提交

如通过show命令查看autocommit的值为ON,表示事务的提交方式是自动提交,此时银行用户表中有一条记录


f11fc814c69640099560fa0b3503bfca.png


在左终端中直接向表中新插入一条记录,由于隔离级别是读未提交,因此在右终端中肯定能够查询到新插入的这条记录


c162d41ba26a41a1811fefd9168c1a63.png


但就算左终端在执行单条SQL后不使用commit进行提交,而直接与MySQL断开连接,这时右终端仍然可以看到之前新插入的记录了,因为单条SQL在执行后被自动提交持久化了


a15dee67dcf746118cb17898c0912808.png


若将autocommit设置为OFF,表示事务执行后需手动提交,此时银行用户表中有两条记录



e03546794b1e4792bf9e43a512dc13df.png

在左终端中直接向表中新插入一条记录,由于隔离级别是读未提交,因此在右终端中肯定能够查询到新插入的这条记录


2972fad673f841c9af8b71b14cd707e1.png


但若此时左终端不使用commit进行提交,而直接与MySQL断开连接,那么这时右终端中就看不到之前新插入的记录了,因为这时单条SQL执行后需使用commit手动提交后才会持久化,在commit之前与MySQL断开连接则会自动进行回滚操作


ebb33bb75ac1424281f725f76e3ed294.png


所以之前的博客中一直都在使用单SQL事务,autocommit默认是打开的,因此单SQL事务执行后自动提交了

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
6月前
|
监控 关系型数据库 MySQL
《MySQL 简易速速上手小册》第8章:事务管理和锁定策略(2024 最新版)
《MySQL 简易速速上手小册》第8章:事务管理和锁定策略(2024 最新版)
58 1
|
6月前
|
SQL 关系型数据库 MySQL
【MySQL】15. 事务管理(重点) -- 1
【MySQL】15. 事务管理(重点) -- 1
39 0
|
SQL 关系型数据库 MySQL
MySQL操作之事务管理
MySQL操作之事务管理
58 0
|
6月前
|
SQL 关系型数据库 MySQL
【MySQL】16.事务管理(重点) -- 2
【MySQL】16.事务管理(重点) -- 2
42 0
|
5月前
|
存储 关系型数据库 MySQL
深入浅出MySQL事务管理与锁机制
MySQL事务确保数据一致性,ACID特性包括原子性、一致性、隔离性和持久性。InnoDB引擎支持行锁、间隙锁和临键锁,提供四种隔离级别。通过示例展示了如何开启事务、设置隔离级别以及避免死锁。理解这些机制对优化并发性能和避免数据异常至关重要。【6月更文挑战第22天】
357 3
|
6月前
|
缓存 关系型数据库 MySQL
【专栏】提升MySQL性能和高可用性的策略,包括索引优化、查询优化和事务管理
【4月更文挑战第27天】本文探讨了提升MySQL性能和高可用性的策略,包括索引优化、查询优化和事务管理。通过合理使用B-Tree和哈希索引,避免过度索引,以及优化查询语句和利用查询缓存,可以改善性能。事务管理中,应减小事务大小并及时提交,以保持系统效率。主从或双主复制可增强高可用性。综合运用这些方法,并根据实际需求调整,是优化MySQL的关键。
221 2
|
6月前
|
关系型数据库 MySQL 测试技术
【MySQL】事务管理 -- 详解(下)
【MySQL】事务管理 -- 详解(下)
|
6月前
|
SQL 关系型数据库 MySQL
【MySQL】事务管理 -- 详解(上)
【MySQL】事务管理 -- 详解(上)
|
6月前
|
关系型数据库 MySQL 数据库
【MySQL】:数据库事务管理
【MySQL】:数据库事务管理
107 0
|
6月前
|
关系型数据库 MySQL 测试技术
【MySQL】16. 事务管理( 重点 | 选学 ) -- 3
【MySQL】16. 事务管理( 重点 | 选学 ) -- 3
48 0
下一篇
无影云桌面