Mysql数据库基础第五章:(一)事务

61 阅读3分钟

本文已参与「新人创作礼」活动,一起开启掘金创作之路

Mysql数据库基础系列

软件下载地址 提取码:7v7u 数据下载地址 提取码:e6p9

1.TCL概述

TCL:Transaction Control Language 事务控制语言 事务: 一个或一组sql语句组成一个执行单元,这个执行单元要么全部执行,要么全部不执行。 案例:经典案例,数据转移,例如皮卡丘和喷火龙初始都有1000元 皮卡丘 1000 喷火龙 1000 喷火龙想要把自己的500给皮卡丘。此时我们需要进行修改 update 表 set 喷火龙余额=500 where name='喷火龙' 但在进行上一句语句之后出现了意外,导致下一句语句执行失败 update 表 set 皮卡丘的余额=1500 where name='皮卡丘' 此时结果将返回 皮卡丘 1000 喷火龙 500 不符合我们想要的结果。因此需要通过事务来将上述语句捆绑在一起。

面试经典题 事务的ACID属性

  • 1.原子性 事务是不可分割的工作单位,事务中的操作都发生或者都不发生
  • 2.一致性 事务必须使数据库从一个一致性状态变换到另外一个一致性状态
  • 3.隔离性 一个事务的执行不被其他事务干扰,一个事务内部操作使用的数据对其他事务隔离,并且各个事务之间互不干扰
  • 4.持久性 一个事务一旦提交,数据库的改变永久

2.事务的创建

隐式事务:事务没有明显的开启和结束的标记 比如insert、update、delete语句 delete from 表 where id =1; mysql默认上述语句为一个事务。 显式事务:事务具有明显的开启和结束的标记 前提:必须先设置自动提交功能为禁用 set autocommit=0;

步骤1:开启事务 set autocommit=0;

步骤2:编写事务中的sql语句(select insert update delete) 语句1; 语句2; ...

步骤3:结束事务 commit;提交事务 rollback;回滚事务

savepoint 节点名;设置保存点

事务的隔离级别: 脏读 不可重复读 幻读 read uncommitted:√ √ √ read committed: × √ √ repeatable read: × × √ serializable × × ×

mysql中默认 第三个隔离级别 repeatable read oracle中默认第二个隔离级别 read committed 查看隔离级别 select @@tx_isolation; 设置隔离级别 set session|global transaction isolation level 隔离级别;

脏读:还没有更新就被读了 不可重复读: 幻读:

3.案例

SHOW VARIABLES LIKE 'autocommit';

#1.演示事务的使用步骤

#开启事务 SET autocommit=0; START TRANSACTION; #编写一组事务的语句

UPDATE account SET balance = 1000 WHERE username='皮卡丘';
UPDATE account SET balance = 1000 WHERE username='喷火龙';

#结束事务 回滚:ROLLBACK; 不执行事务 提交:commit;执行事务

SELECT * FROM account;

#2.演示savepoint 的使用

SET autocommit=0;
START TRANSACTION;
DELETE FROM account WHERE id=25;
SAVEPOINT a;#设置保存点
DELETE FROM account WHERE id=28;
ROLLBACK TO a;#回滚到保存点
SELECT * FROM account;

上述只删除了25号的数据,28号的数据为删除

演示事务对于delete和truncate的处理的区别

SET autocommit=0;
START TRANSACTION;
DELETE FROM account;
ROLLBACK;

delete支持回滚

SET autocommit=0;
START TRANSACTION;
DELETE FROM account;
ROLLBACK;

使用truncate不支持回滚