mysql - 事务隔离可重复读深入理解

我们都知道在mysql中默认的事务隔离级别是 “ repeatable read”,从字面意思上我们来理解就是可重复读,就是session事件开始时其他session对数据作的变更无法感应到,到事实上是这样吗?

我们来做一个例子。

比如我们有这一条记录

mysql> select * from user where id=1;

+----+---------+------+--------------------+---------+------------+---------+------+--------+-----------+

| id | name | age | email | deleted | createtime | version | FAB | specid | work_info |

+----+---------+------+--------------------+---------+------------+---------+------+--------+-----------+

| 1 | fuckyou | 99 | test1@baomidou.com | 1 | NULL | 0 | FAB1 | NULL | NULL |

+----+---------+------+--------------------+---------+------------+---------+------+--------+-----------+

1 row in set (0.00 sec)

1.我们开始三个客户端都开启begin事务

2.我们在客户端1上查询结果如下

mysql> select * from user where id=1;

+----+---------+------+--------------------+---------+------------+---------+------+--------+-----------+

| id | name | age | email | deleted | createtime | version | FAB | specid | work_info |

+----+---------+------+--------------------+---------+------------+---------+------+--------+-----------+

| 1 | fuckyou | 99 | test1@baomidou.com | 1 | NULL | 0 | FAB1 | NULL | NULL |

+----+---------+------+--------------------+---------+------------+---------+------+--------+-----------+

1 row in set (0.00 sec)

3.我们在客户端2上update age为98,并且commit结束事务

mysql> update user set age=98 where id=1;

Query OK, 1 row affected (0.02 sec)

Rows matched: 1 Changed: 1 Warnings: 0

mysql> commit;

Query OK, 0 rows affected (0.08 sec)

4.我们在客户1在查询一次,发现age值未做变更还是99

mysql> select * from user where id=1;

+----+---------+------+--------------------+---------+------------+---------+------+--------+-----------+

| id | name | age | email | deleted | createtime | version | FAB | specid | work_info |

+----+---------+------+--------------------+---------+------------+---------+------+--------+-----------+

| 1 | fuckyou | 99 | test1@baomidou.com | 1 | NULL | 0 | FAB1 | NULL | NULL |

+----+---------+------+--------------------+---------+------------+---------+------+--------+-----------+

1 row in set (0.00 sec)

5.我们客户端3上进行查询,发现age已变为98

mysql> select * from user where id=1;

+----+---------+------+--------------------+---------+------------+---------+------+--------+-----------+

| id | name | age | email | deleted | createtime | version | FAB | specid | work_info |

+----+---------+------+--------------------+---------+------------+---------+------+--------+-----------+

| 1 | fuckyou | 98 | test1@baomidou.com | 1 | NULL | 0 | FAB1 | NULL | NULL |

+----+---------+------+--------------------+---------+------------+---------+------+--------+-----------+

1 row in set (0.00 sec)

6.我们在客户1进行commit结束事务,在查询一 次,发现age变为98

mysql> commit

-> ;

Query OK, 0 rows affected (0.00 sec)

mysql> select * from user where id=1;

+----+---------+------+--------------------+---------+------------+---------+------+--------+-----------+

| id | name | age | email | deleted | createtime | version | FAB | specid | work_info |

+----+---------+------+--------------------+---------+------------+---------+------+--------+-----------+

| 1 | fuckyou | 98 | test1@baomidou.com | 1 | NULL | 0 | FAB1 | NULL | NULL |

+----+---------+------+--------------------+---------+------------+---------+------+--------+-----------+

1 row in set (0.00 sec)

从以上的事例中我们得到这样结论,mysql可重复是在事务开始之后执行第一个sql才生成可重复读的数据镜像,而不是begin一始就生成重复读的数据,且这种重复读数据一直维持到当前事务结束。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值