MySQL的事务-可重复读

        MySQL数据库的默认事务隔离级别是可重复读(Repeatable Read)。在这个隔离级别下,可以解决读已提交(Read Committed)产生的幻读问题,事务在开始时创建一个数据快照,并在整个事务期间使用这个快照进行读取操作,确保读取的数据在事务内保持一致。

        可重复读事务隔离级别的主要特点有:

(1)一致性读:因为在可重复读隔离级别下,事务的Select操作会读取到事务开始时的数据快照。

(2)行级锁:当一个事务修改一行数据时,会锁定该行,防止其他事务同时修改或删除该行,这样可以保证事务的原子性和隔离性。

(3)多版本并发控制(MVCC): MySQL使用多版本并发控制机制来实现可重复读隔离级别。每个事务都会看到一个独立的数据版本,不同的事务之间不会相互干扰。

在MySQL数据库的隔离级别时可重复读(Repeatable Read)的情况,验证数据不会产生幻读。

测试一、

连接A:开启事务

在连接B中,插入一条数据:

在连接B中,可以查询到4条记录,但是在连接A中,仍然是原来的三条记录,如下所示:

测试二:

在连接A中开启事务:

在连接B中修改id=3的money值,

但是在连接A中看到的仍然是事务开始时的值。

通过测试一、测试二可以看到,MySQL的Repeatable Read事务隔离级别确保了事务的一致性。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

程序猿2023

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

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

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

打赏作者

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

抵扣说明:

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

余额充值