事务隔离级别简易演示列子

读未提交

建表
CREATE TABLE user (
id int(11) NOT NULL,
name varchar(20) DEFAULT NULL,
age int(11) NOT NULL,
PRIMARY KEY (id),
UNIQUE KEY name (name)
)

读未提交

session 1: SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
session 1:begin;

session 2:begin;
session 2:insert into user(id,name,age) values(1, “张三”, 20);
session 1: select * from user; (脏读)
在这里插入图片描述
session 2: rollback;
session 1: select * from user;
Empty set (0.00 sec)
session 1: commit;

读已提交

session 1: SET TRANSACTION ISOLATION LEVEL READ COMMITTED;
session 1: begin

session 2: begin;
session 2: insert into user(id,name,age) values(1, “张三”, 20);
session 1: select * from user;
Empty set (0.00 sec)

session 2: commit;
session 1: select * from user;
在这里插入图片描述

可重复读

快照读与当前读

session 1: SET TRANSACTION ISOLATION LEVEL REPEATABLE READ;
session 1: begin;

session 2: begin;
session 2: insert into user(id,name,age) values(3, “李四”, 20);

session 1:select * from user;(快照读)
在这里插入图片描述

session 2: commit;
session 1: select * from user;
在这里插入图片描述

session 1: select * from user for update;(直接读)
在这里插入图片描述

快照建立在第一次执行查询语句的时候

session 1: begin;
session 2: begin;
session 3: begin;
session 1: select * from user;
在这里插入图片描述

session 3:update user set age = 21 where id = 3;
session 3:commit;

session 1: select * from user;
在这里插入图片描述

session2 : select * from user;
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值