(1)READ UNCOMMITED(未提交可读)-- 事务1修改了数据A后未提交,事务2可以读到被事务1修改的数据A,但是事务1可能最终不提交,那么事务2读到的就是错误的数据(脏数据)
(2)READ COMMITED(提交了可读)-- 事务1读取了数据A后未提交,事务2修改了数据A且提交,然后事务1再去读数据A会发现前后两次读结果不同,这就是不可重复读(因为重复读结果不一样)
(3)REAPATABLE READ(可重复读)-- 事务1读取了数据A后未提交,事务2修改了数据A且提交,然后事务1再去读数据A会发现前后两次读结果相同,这就是可重复读 – MYSQL默认级别
(4)SERIALIZABLE(可串行化)-- 每一行数据加锁,导致所有事务都必须串行执行,但是代价很大
我将sql的四种隔离级别编成小故事,为了方便记忆,:
1,未提交可读 - 同学A 约我可能下午一起去游玩, 而后 同学B约我出去玩, 却被妈妈告知我已经有约了, 但是 同学A可能下午有其他的事, 未能和我一起出去玩,此时 同学B获取到的信息就是有误的了!
2,提交了可读 - 同学A 约我可能下午一起去游玩, 而后 同学B约我出去玩,我同意并和他一起出去玩了, 此时 同学A来找我 发现我已经出去了!
3,可重复读 - 同学A 约我可能下午一起去游玩, 而后 同学B约我出去玩,我同意并和他一起出去玩了,我主动告知同学A ,同学A来找我和同学B 一起游玩.