mysql 事务 Read Committed

在ReadCommitted隔离级别下,事务可能会遇到不可重复读问题,即同一个事务内多次读取同一数据可能存在不一致。然而,此级别有效防止了脏读的发生。通过实例展示了在两个并发事务中,如何出现不可重复读的情况,但未出现脏读。
摘要由CSDN通过智能技术生成

在这之前介绍了mysql隔离级别最低的一种事务级别 Read Uncommitted

在Read Committed隔离级别下,一个事务可能会遇到不可重复读(Non Repeatable Read)的问题。不可重复读是指,在一个事务内,多次读同一数据,在这个事务还没有结束时,如果另一个事务恰好修改了这个数据,那么,在第一个事务中,两次读取的数据就可能不一致。

但同时,这种隔离级别也避免了出现脏读。

我们来测试一下,首先准备一个有数据的student表:

然后,分别开启两个MySQL客户端连接,按顺序依次执行事务A和事务B:

时刻事务A事务B
1SET TRANSACTION ISOLATION LEVEL READ COMMITTED;SET TRANSACTION ISOLATION LEVEL READ COMMITTED;
2BEGIN;BEGIN;
3SELECT * FROM student; 
4UPDATE student SET name = '小王' WHERE id = 1;
5SELECT * FROM student; 
6COMMIT;
7SELECT * FROM student;
8COMMIT;

 

 当事务B第一次执行第3步的查询时,得到的结果是 张三 ,随后,事务A在第4步更新了这条记录没有提交,事务B在第5步再次执行同样的查询时,得到的结果还是 张三 ,事务A在第6步提交事务后,事务B在第7步再次查询,得到的结果还是 小王 。因此,在Read Committed隔离级别下,事务不可重复读同一条记录,因为很可能读到的结果不一致,但同时也避免了脏读。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

YuanlongWang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值