前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【Mysql】一文解读【事务】-【基本操作/四大特性/并发事务问题/事务隔离级别】

【Mysql】一文解读【事务】-【基本操作/四大特性/并发事务问题/事务隔离级别】

作者头像
YY的秘密代码小屋
发布2024-04-03 09:36:30
870
发布2024-04-03 09:36:30
举报
文章被收录于专栏:C++系列C++系列

前言 大家好吖,欢迎来到 YY 滴MySQL系列 ,热烈欢迎! 本章主要内容面向接触过C++ Linux的老铁 主要内容含:

基本内容总览

  • 详细内容查看下文

一.事务简介

  • 核心理念: 把一系列操作当作一个整体

二.事务操作(模拟转账失败)

1.事务操作系列语法1-【查看/设置事务提交方式–提交事务–回滚事务】

  • 自动:@@autocommit=1
  • 手动:@@autocommit=0
代码语言:javascript
复制
--查看事务提交方式
SELECT @@autocommit ;//会显示 @@autocommit=1;默认为自动

--设置事务提交方式
SET @@autocommit=0;//手动

--提交事务
COMMIT;

--回滚事务
ROLLBACK ;

2.事务操作系列语法2-【开启事务–提交事务–回滚事务】

  • 总览如下
代码语言:javascript
复制
--开启事务
START TRANSACTION 或 BEGIN;

--提交事务
COMMIT ;

--回滚事务
ROLLBACK;

※数据准备环节

代码语言:javascript
复制
-- 数据准备
create table account(
    id int auto_increment primary key comment '主键ID',
    name varchar(10) comment '姓名',
    money int comment '余额'
) comment '账户表';
insert into account(id, name, money) VALUES (null,'张三',2000),(null,'李四',2000);


-- 恢复数据操作
update account set money = 2000 where name = '张三' or name = '李四';

3.模拟转账失败-(方式一:修改事务提交方式为手动)

  • 我们这个实验要用到上面的系列语法1
代码语言:javascript
复制
--查看事务提交方式
SELECT @@autocommit ;//会显示 @@autocommit=1;默认为自动

--设置事务提交方式
SET @@autocommit=0;//手动

--提交事务
COMMIT;

--回滚事务
ROLLBACK ;

  • 如下方代码所示,我们用程序执行报错 ...模拟抛异常
  • 此时由于我们 设置为手动提交 set @@autocommit = 0; 所以事务并未提交;
  • 后续rollback ; 回滚事务即可;
代码语言:javascript
复制
-- 方式一
select @@autocommit;

set @@autocommit = 0; -- 设置为手动提交

-- 转账操作 (张三给李四转账1000)
-- 1. 查询张三账户余额
select * from account where name = '张三';

-- 2. 将张三账户余额-1000
update account set money = money - 1000 where name = '张三';

程序执行报错 ...//模拟抛异常

-- 3. 将李四账户余额+1000
update account set money = money + 1000 where name = '李四';

-- 提交事务
commit;

-- 回滚事务
rollback ;

4.模拟转账失败-(方式二:不修改事务提交方式,自动)

  • 我们这个实验要用到上面的系列语法2
代码语言:javascript
复制
--开启事务
START TRANSACTION 或 BEGIN;

--提交事务
COMMIT ;

--回滚事务
ROLLBACK;

  • 开始操作前记得 改回自动提交 set @@autocommit = 1; -- 改回自动提交
  • 如下方代码所示,我们用程序执行报错 ...模拟抛异常
  • 此时由于我们 开启了事务 start transaction ; 所以事务报错后并未提交;
  • 后续rollback ; 回滚事务即可;
代码语言:javascript
复制
-- 方式二
-- 改回自动提交
set @@autocommit = 1; 

-- 转账操作 (张三给李四转账1000)
start transaction ;

-- 1. 查询张三账户余额
select * from account where name = '张三';

-- 2. 将张三账户余额-1000
update account set money = money - 1000 where name = '张三';

程序执行报错 ...

-- 3. 将李四账户余额+1000
update account set money = money + 1000 where name = '李四';


-- 提交事务
commit;

-- 回滚事务
rollback;

三.事务四大特性(A-C-I-D)

  • 如下图所示

四.并发事务问题(脏读-幻读-不可重复读)

基本概念一览

  • 脏读:一个事务 读到 另外一个事务还 没有提交的数据。
  • 不可重复读:一个事务 先后读取同一条记录,但两次读取的 数据不同,称之为不可重复读。
  • PS:不可重复读是解决脏读导致的
  • 幻读:一个事务按照条件 查询数据时 没有对应的数据行,但是在 插入数据时,又发现这行数据 已经存在,好像出现了幻影”。
  • PS:幻读是解决不可重复读导致的

1.脏读

  • 脏读:一个事务 读到 另外一个事务还 没有提交的数据。
  • 如下图所示:

2.不可重复读

  • 不可重复读:一个事务 先后读取同一条记录,但两次读取的 数据不同,称之为不可重复读。
  • PS:不可重复读是解决脏读导致的
  • 如下图所示:

3.幻读

  • 幻读:一个事务按照条件 查询数据时 没有对应的数据行,但是在 插入数据时,又发现这行数据 已经存在,好像出现了幻影”。
  • PS:幻读是解决不可重复读导致的
  • 如下图所示:

五.事务隔离级别

1.事务隔离级别&要点

  • 要点:事务隔离级别越高,数据越 安全 ,但是 性能 越低。

  • 事务隔离级别,如下所示:

2.查看/修改事务隔离级别语法

  • 如下图所示
  • 下图:修改隔离级别后查看
代码语言:javascript
复制
--查看事务隔离级别语法
SELECT @@TRANSACTION_ISOLATION;

--修改事务隔离级别语法
SET [SESSION|GLOBLE] TRANSACTION ISOLATION LEVEL {READ UNCOMMITTED | READ COMMITTED | REPEATABLE READ | SERIALIZABLE}

3.用两个Mysql客户端模拟并发事务,并测试各个隔离级别效果

※事务回顾隔离级别

  • 事务隔离级别,如下所示:
1.模拟脏读

  • 脏读:一个事务 读到 另外一个事务还 没有提交的数据。
2.修改隔离级别——[避免脏读—>不可重复读]

  • 不可重复读:一个事务 先后读取同一条记录,但两次读取的 数据不同,称之为不可重复读。
  • PS:不可重复读是解决脏读导致的
  • 现象: 同样sql在同一语句查询中不一致
3.修改隔离级别——[避免不可重复读—>幻读]

  • 幻读:一个事务按照条件 查询数据时 没有对应的数据行,但是在 插入数据时,又发现这行数据 已经存在,好像出现了幻影”。
  • PS:幻读是解决不可重复读导致的
  • 注意:我们这次实验不用修改隔离级别,因为是默认的(如果已经修改了同上面改回来即可)
  • 现象如图所示:
4.修改隔离级别——[避免幻读—>进入阻塞状态]

  • 阻塞状态:在阻塞状态下,进程或线程可能会被挂起,直到条件满足或事件发生后才能被唤醒并继续执行。
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2024-04-03,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 基本内容总览
  • 一.事务简介
  • 二.事务操作(模拟转账失败)
    • 1.事务操作系列语法1-【查看/设置事务提交方式–提交事务–回滚事务】
      • 2.事务操作系列语法2-【开启事务–提交事务–回滚事务】
        • ※数据准备环节
          • 3.模拟转账失败-(方式一:修改事务提交方式为手动)
            • 4.模拟转账失败-(方式二:不修改事务提交方式,自动)
            • 三.事务四大特性(A-C-I-D)
            • 四.并发事务问题(脏读-幻读-不可重复读)
              • 基本概念一览
                • 1.脏读
                  • 2.不可重复读
                    • 3.幻读
                    • 五.事务隔离级别
                      • 1.事务隔离级别&要点
                        • 2.查看/修改事务隔离级别语法
                          • 3.用两个Mysql客户端模拟并发事务,并测试各个隔离级别效果
                            • ※事务回顾隔离级别
                            • 1.模拟脏读
                            • 2.修改隔离级别——[避免脏读—>不可重复读]
                            • 3.修改隔离级别——[避免不可重复读—>幻读]
                            • 4.修改隔离级别——[避免幻读—>进入阻塞状态]
                        相关产品与服务
                        云数据库 MySQL
                        腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
                        领券
                        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档