前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >浅谈MySQL中的事务隔离级别(r11笔记第86天)

浅谈MySQL中的事务隔离级别(r11笔记第86天)

作者头像
jeanron100
发布2018-03-21 14:44:43
6410
发布2018-03-21 14:44:43
举报
文章被收录于专栏:杨建荣的学习笔记

之前写了一篇浅谈事务(一),算是对事务的一个基本认识,今天来简单总结一下事务的隔离级别,虽然是老掉牙的知识点,重温一下还是值得的。

在MySQL中基本有这两种事务隔离级别的设置,默认的RR(Repeatable-Read)和实际中常见的RC(Read-Committed)。两者区别是什么,怎么正确理解,用几个SQL语句就能说明白,就用简单的实验来说明白。

我们开始吧。

首先创建一个测试表test,插入一些数据。

create table test( id int primary key,name varchar(30),memo varchar(30)); insert into test values(1,'name1','aaaa'),(2,'name2','aaaa'),(3,'name3','aaaa'),(4,'name4','aaaa'),(5,'name5','aaaa'); 很多情况下,我们会把隔离级别从默认的RR修改为RC,这也是其它很多数据库默认的事务隔离级别。

我们打开两个窗口,来对比关联测试。

RC模式下的测试

1-窗口1

代码语言:javascript
复制
>show variables like 'tx_isolation';   
+---------------+----------------+
| Variable_name | Value          |
+---------------+----------------+
| tx_isolation  | READ-COMMITTED |
+---------------+----------------+
1 row in set (0.01 sec)
代码语言:javascript
复制
>begin;  --开启事务 
>select *from test;  --查看数据
+----+-------+------+
| id | name  | memo |
+----+-------+------+
|  1 | name1 | aaaa |
|  2 | name2 | aaaa |
|  3 | name3 | aaaa |
|  4 | name4 | aaaa |
|  5 | name5 | aaaa |
+----+-------+------+
5 rows in set (0.00 sec)

2-窗口2

代码语言:javascript
复制
begin;  --开启事务
>update test set name='aaaaa' where id=2;  --修改一条记录
Query OK, 1 row affected (0.06 sec)
Rows matched: 1  Changed: 1  Warnings: 0
>commit;  --提交事务
Query OK, 0 rows affected (0.01 sec)

1-窗口1

>select *from test; --查看窗口1中的数据,就会发现原来窗口的数据发生了变化,这是不可重复读的一个典型例子。 +----+-------+------+ | id | name | memo | +----+-------+------+ | 1 | name1 | aaaa | | 2 | aaaaa | aaaa | | 3 | name3 | aaaa | | 4 | name4 | aaaa | | 5 | name5 | aaaa | +----+-------+------+ 5 rows in set (0.00 sec)

RR模式下的测试

再来看看RR这个隔离级别,其实有了上面的测试,就相对有底了。这是MySQL默认的隔离级别,会出现幻读的情况。

1-窗口1

首先修改隔离级别从RC到RR

代码语言:javascript
复制
>set global transaction isolation level repeatable read; 
Query OK, 0 rows affected (0.00 sec)
?查看事务隔离级别。
>show variables like 'tx_isolation';
+---------------+-----------------+
| Variable_name | Value           |
+---------------+-----------------+
| tx_isolation  | REPEATABLE-READ |
+---------------+-----------------+
1 row in set (0.00 sec)

>begin; --开启事务 >select *from test; --查看表test的数据。 +----+-------+------+ | id | name | memo | +----+-------+------+ | 1 | name1 | aaaa | | 2 | aaaaa | aaaa | | 3 | name3 | aaaa | | 4 | name4 | aaaa | | 5 | name5 | aaaa | +----+-------+------+ 5 rows in set (0.00 sec)

2-窗口2

>begin; --开启事务 >update test set name='RR_test'; --修改表test的数据,所有记录都发生变化。 Query OK, 5 rows affected (0.01 sec) Rows matched: 5 Changed: 5 Warnings: 0 >commit; --提交事务 Query OK, 0 rows affected (0.00 sec)

1-窗口1 >select *from test; --在RR模式下,窗口1中的事务因为还没有提交,看到的还是原来的数据。 +----+-------+------+ | id | name | memo | +----+-------+------+ | 1 | name1 | aaaa | | 2 | aaaaa | aaaa | | 3 | name3 | aaaa | | 4 | name4 | aaaa | | 5 | name5 | aaaa | +----+-------+------+ 5 rows in set (0.00 sec) >commit; --我们提交窗口1的事务 Query OK, 0 rows affected (0.00 sec) >select *from test; --再次查看数据就发生了变化,实际上窗口1中没有任何的DMl操作。 +----+---------+------+ | id | name | memo | +----+---------+------+ | 1 | RR_test | aaaa | | 2 | RR_test | aaaa | | 3 | RR_test | aaaa | | 4 | RR_test | aaaa | | 5 | RR_test | aaaa | +----+---------+------+ 5 rows in set (0.00 sec)

小结

用一个通俗的例子来说明,比如加工资,领导叫你去谈话,然后给你加薪10%,RC的情况就是当月就立即生效;而RR的情况是,领导叫你去谈话了,结果过了两个月你看到工资还是没变,到了第3个月,把前两个月加薪的部分也补给你了。大概就是这样的意思,总体来说,我更倾向于RC级别。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2017-02-25,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 杨建荣的学习笔记 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档