一)可读取未确认(Read uncommitted)

写事务阻止其他写事务,避免了更新遗失。但是没有阻止其他读事务。

存在的问题:脏读。即读取到不正确的数据,因为另一个事务可能还没提交最终数据,这个读事务就读取了中途的数据,这个数据可能是不正确的。

解决办法就是下面的“可读取确认”。

(二)可读取确认(Read committed)

写事务会阻止其他读写事务。读事务不会阻止其他任何事务。

存在的问题:不可重复读。即在一次事务之间,进行了两次读取,但是结果不一样,可能第一次id为1的人叫“李三”,第二次读id为1的人就叫了“李四”。因为读取操作不会阻止其他事务。

解决办法就是下面的“可重复读”。

(三)可重复读(Repeatable read)

存在的问题:幻读。当事务开启的时候,默认读的是此时数据库中的数据。假设读到了10条,然后进行更新操作了10条,惊奇的发现更新了20条。是因为其他地方插入了10条数据,导致了事务中的幻读,以为只更新了读到了10条。实则他更新了数据库中的所有满足数据。

(四)可串行化(Serializable)

读加共享锁,写加排他锁。这样读取事务可以并发,但是读写,写写事务之间都是互斥的,基本上就是一个个执行事务,所以叫串行化。

11-17 14:18