MySQL 数据库 - 事务

MySQL 数据库(基础)- 事务

事务简介

事务 是一组操作集合,他是一个不可分割的工作单位,事务会把所有的操作看作是一个整体一起向系统发送请求,即这些操作要么同时成功,要么同时失败。

比如:张三给李四转账1000元,张三账户里减少1000元,李四账户里增加1000元;这一组操作必须在一个事务的范围内,要么都成功,要么都失败。
在这里插入图片描述

注意:默认MySQL的事务是自动提交的,也就是说,当执行完一条 DML 语句时,MySQL会立即隐式的提交事务。

事务操作

数据准备:

drop table if exists account;

create table account(
	id int primary key AUTO_INCREMENT comment 'ID',
	name varchar(10) comment '姓名',
	money double(10,2) comment '余额'
) comment '账户表';

insert into account(name, money) VALUES ('张三',2000), ('李四',2000);

为控制事务

  1. 测试正常情况
-- 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 = '李四';

测试完毕之后检查数据的状态, 可以看到数据操作前后是一致的。
在这里插入图片描述
2. 测试异常情况

-- 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 = '李四';

我们把数据都恢复到2000, 然后再次一次性执行上述的SQL语句(出错了… 这句话不符合SQL语法,执行就会报错),检查最终的数据情况, 发现数据在操作前后不一致了。
在这里插入图片描述

控制事务

  1. 查看 / 设置事务提交方式
SELECT @@autocommit ;

SET @@autocommit = 0 ;
  1. 提交事务
COMMIT;
  1. 回滚事务
ROLLBACK;

注意:上述这种方式,我们是修改了事务的自动提交行为,把默认自动提交修改为了手动提交,此时执行DML语句不会自动提交,需要手动执行commit进行提交。

控制事务二

  1. 开始事务
START TRANSACTIONBEGIN ;
  1. 提交事务
COMMIT;
  1. 回滚事务
ROLLBACK;

转账案例:

-- 开启事务
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;

事务四大特性

  • 原子性(Atomicity):事务是不可分割的最小操作单元,要么全部成功,要么全部失败。
  • 一致性(Consistency):事务完成时,必须使所有的数据都保持一致状态。
  • 隔离性(Isolation):数据库系统提供的隔离机制,保证事务在不受外部并发操作影响的独立环境下运行。
  • 持久性(Durability):事务一旦提交或回滚,它对数据库中的数据的改变就是永久的。

上述就是事务的四大特性,简称ACID。
在这里插入图片描述

并发事务问题

  1. 脏读:一个事务读到另外一个事务还没有提交的数据。
    在这里插入图片描述
    比如 B 读取到了 A 未提交的数据。

  2. 不可重复读:一个事务先后读取同一条记录,但是两次读取到的数据不同,称之为不可重复读。
    在这里插入图片描述
    事务 A 两次读取同一条数据,但是读取到的数据却是不一样的。

  3. 幻读:一个事务按条件查询数据时,没有对应的数据行,但是插入数据时,又发现这行数据已经存在,好像出现了“幻影”。
    在这里插入图片描述

事务隔离级别

为了解决并发事务所引发的问题,在数据库中引入了事务隔离级别。主要有以下几种:
在这里插入图片描述

  1. 查看事务隔离级别
SELECT @@TRANSACTION_ISOLATION;
  1. 设置事务隔离级别
SET [ SESSION | GLOBAL ] TRANSACTION ISOLATION LEVEL { READ UNCOMMITTED | READ COMMITTED | REPEATABLE READ | SERIALIZABLE }

注意:事务隔离级别越高,数据越安全,但是性能就越低。

相关推荐

  1. MySQL数据库事务

    2024-07-15 17:50:02       46 阅读
  2. 数据库MySQL索引事务

    2024-07-15 17:50:02       31 阅读
  3. MySQL数据库——18、事务

    2024-07-15 17:50:02       27 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-15 17:50:02       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-15 17:50:02       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-15 17:50:02       58 阅读
  4. Python语言-面向对象

    2024-07-15 17:50:02       69 阅读

热门阅读

  1. 721. 账户合并 Medium

    2024-07-15 17:50:02       23 阅读
  2. DMA和DMAC

    2024-07-15 17:50:02       21 阅读
  3. 面试官:说说MySQL 中的悲观锁和乐观锁

    2024-07-15 17:50:02       20 阅读
  4. Redis① —— Redis基础

    2024-07-15 17:50:02       20 阅读
  5. LeetCode 445.两数相加||

    2024-07-15 17:50:02       16 阅读
  6. openstack

    2024-07-15 17:50:02       19 阅读
  7. Memcached与Redis:缓存解决方案的较量与选择

    2024-07-15 17:50:02       21 阅读