Mysql事务隔离级别之读未提交
Mysql Mysql 事务
2019-01-04 10:01:08 236 0

Mysql事务隔离级别之读未提交

查看mysql 事务隔离级别

mysql> show variables like '%isolation%';
+---------------+------------------+
| Variable_name | Value            |
+---------------+------------------+
| tx_isolation  | READ-UNCOMMITTED |
+---------------+------------------+
1 row in set (0.00 sec)

可以看到当前的事务隔离级别为 READ-UNCOMMITTED 读未提交

下面看看当前隔离级别下的事务隔离详情,开启两个查询终端A、B。

下面有一个order表,初始数据如下

mysql> select * from `order`;
+----+--------+
| id | number |
+----+--------+
| 13 |      1 |
+----+--------+
1 row in set (0.00 sec)
第一步,在A,B中都开启事务
mysql> start transaction;
Query OK, 0 rows affected (0.00 sec)
第二步查询两个终端中的number
  • A
 mysql> select * from `order`;
+----+--------+
| id | number |
+----+--------+
| 13 |      1 |
+----+--------+
1 row in set (0.00 sec)
  • B
 mysql> select * from `order`;
+----+--------+
| id | number |
+----+--------+
| 13 |      1 |
+----+--------+
1 row in set (0.00 sec)
第三步将B中的number修改为2,但不提交事务
mysql> update `order` set number=2;
Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 0
第四步查询A中的值
mysql> select * from `order`;
+----+--------+
| id | number |
+----+--------+
| 13 |      2 |
+----+--------+
1 row in set (0.00 sec)

发现A中的值已经修改。

第五步,提交事务B,再次查询A中的值
  • B
    mysql> commit;
    Query OK, 0 rows affected (0.01 sec)
  • A
mysql> select * from `order`;
+----+--------+
| id | number |
+----+--------+
| 13 |      2 |
+----+--------+
1 row in set (0.00 sec)

发现A中的值还是2

第六步,提交A中的事务,再次查询A,B的值。
  • A
mysql> commit;
Query OK, 0 rows affected (0.00 sec)

mysql> select * from `order`;
+----+--------+
| id | number |
+----+--------+
| 13 |      2 |
+----+--------+
1 row in set (0.00 sec)
  • B
    mysql> select * from `order`;
    +----+--------+
    | id | number |
    +----+--------+
    | 13 |      2 |
    +----+--------+
    1 row in set (0.00 sec)

    发现A,B中的值都为2。

下面给一个简单的示意图

未命名文件.png

我们可以看到,在事务隔离级别为读未提交的情况下,当B中的值改变。不管B事务是否提交,A都会拿到更改之后的值。这样既不能解决脏读也不用能解决幻读
0条评论