innoDB默认隔离级别
mysql> SELECT @@tx_isolation;
+-----------------+
| @@tx_isolation |
+-----------------+
| REPEATABLE-READ |
+-----------------+
两个事务同时更新一条数据
右图第二个事务的update增加行锁(表中id有索引), 在未提交之前,左图第一个事务update操作会进入阻塞状态, 左图中仍然可以进行select
右图第二个事务提交之后, 第一个事务会执行update并返回结果,但是还没有提交, 此时右图的查询结果是第二个事务提交的值
然后左图第一个事务也提交, 会覆盖右图第二个事务的值。左图操作的是右图变更前的数据,这个在并发时是不正常的
更新数据库的隔离级别为序列化
开启两个事务, 右图进行update操作, 左图事务的select操作会进入阻塞操作
右图提交之后, 左图事务select返回右图提交之后的结果
此时左图再update commit, 会覆盖右图的结果。左图操作的是右图变更后的数据, 这个在并发时是正常的.