MySQL 中事务以及事务隔离级别的详解

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: MySQL 中事务以及事务隔离级别的详解

一、MySQL 中事务的理解

二、演示事务的基本使用

DROP TABLE t27;
-- 1.创建一张测试表
CREATE TABLE t27(
id INT,
`name` VARCHAR(32)
);
-- 2.开启事务
START TRANSACTION
-- 3.设置保存点
SAVEPOINT a
-- 执行DML操作
INSERT INTO t27 VALUES(100,'tom');
SELECT * FROM t27;
SAVEPOINT b
-- 执行DML操作
INSERT INTO t27 VALUES(200,'jack');
-- 回退到b
ROLLBACK TO b
-- 继续回退 a
ROLLBACK TO a
-- 如果这样,表示直接回退到事务开始的状态
ROLLBACK

三、回退事务和提交事务的介绍

四、MySQL事务细节讨论

对应的SQL语句如下

-- 讨论 事务细节
INSERT INTO t27 values(300,'milan'); -- 自动提交 commit
SELECT * FROM t27;
-- 如果开始一个事务,你没有创建保存点,你可以执行rollback
-- 默认就是回退到你事务开始的状态
START TRANSACTION
INSERT INTO t27 VALUES(400,'King');
INSERT INTO t27 VALUES(500,'scott');
ROLLBACK -- 直接回退到事务开始的状态
COMMIT
-- INNODB 存储引擎支持事务,MyISAM不支持    
-- 开启事务 START TRANSACTION 也可以这样写SET autocommit=off
SET autocommit=off
INSERT INTO t27 VALUES(400,'King');
INSERT INTO t27 VALUES(500,'scott');
SELECT * FROM t27;
ROLLBACK

五、MySQL中的事务隔离级别

1、事务隔离级别的介绍

2、脏读,不可重复度,幻读的理解

3、事务的4隔离级别如下

4、查看与设置隔离级别

对应的SQL代码如下

-- 演示mysql事务的隔离级别
-- 1.开了两个mysql的控制台
-- 2.查看当前mysql的隔离级别
SELECT @@transaction_isolation;
-- +-------------------------+
-- | @@transaction_isolation |
-- +-------------------------+
-- | REPEATABLE-READ         |
-- +-------------------------+
-- 3.把其中一个控制台的隔离级别设置 READ-UNCOMMITTED
SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
CREATE TABLE `account`(
id INT,
name VARCHAR(32),
money INT
);
-- 查看当前会话隔离级别
SELECT @@transaction_isolation;
-- 查看系统当前隔离级别
SELECT @@global.transaction_isolation;
-- 设置当前会话隔离级别
SET SESSION TRANSACTION ISOLATION LEVEL REPEATABLE READ;
-- 设置系统当前隔离级别
SET GLOBAL TRANSACTION ISOLATION LEVEL [你设置的级别];

六、事务ACID的特性


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
6天前
|
SQL 存储 缓存
【MySQL】事务
【MySQL】事务
15 0
|
6天前
|
SQL 存储 关系型数据库
MySQL索引及事务
MySQL索引及事务
25 2
|
6天前
|
存储 关系型数据库 MySQL
MySQL事务简述
MySQL事务简述
6 0
|
6天前
|
存储 算法 关系型数据库
MySQL事务与锁,看这一篇就够了!
MySQL事务与锁,看这一篇就够了!
|
6天前
|
Java 关系型数据库 MySQL
MySQL 索引事务
MySQL 索引事务
14 0
|
6天前
|
SQL 安全 关系型数据库
【Mysql-12】一文解读【事务】-【基本操作/四大特性/并发事务问题/事务隔离级别】
【Mysql-12】一文解读【事务】-【基本操作/四大特性/并发事务问题/事务隔离级别】
|
6天前
|
存储 关系型数据库 MySQL
Mysql学习--深入探究索引和事务的重点要点与考点
Mysql学习--深入探究索引和事务的重点要点与考点
|
6天前
|
存储 SQL 关系型数据库
Mysql_数据库事务
Mysql_数据库事务
|
6天前
|
缓存 关系型数据库 MySQL
【专栏】提升MySQL性能和高可用性的策略,包括索引优化、查询优化和事务管理
【4月更文挑战第27天】本文探讨了提升MySQL性能和高可用性的策略,包括索引优化、查询优化和事务管理。通过合理使用B-Tree和哈希索引,避免过度索引,以及优化查询语句和利用查询缓存,可以改善性能。事务管理中,应减小事务大小并及时提交,以保持系统效率。主从或双主复制可增强高可用性。综合运用这些方法,并根据实际需求调整,是优化MySQL的关键。
|
6天前
|
Java 关系型数据库 MySQL
{MySQL}索引事务和JDBC
{MySQL}索引事务和JDBC
21 0