【推荐】2019 Java 开发者跳槽指南.pdf(吐血整理) >>>
四个概念:
数据丢失、脏读、不可重复读、幻读
数据丢失,两个事务同时进行,一个成功一个失败,造成数据回滚,或者两个都成功造成数据覆盖
从这个概念,就可以看出事务隔离的必要性,如果没有的话很容易产生这个严重的问题
脏读:在一个事务里面,读取到另一个事务还没提交的数据
不可重复读:一个事务内两次读同一个数据,可能发生变化(一般指该数据事务期间被别的事务修改,理解对一条数据操作)
幻读:一个事务内两次查询数据不一致(条件查询,理解多条数据,其他事务有新增或者删除)
事务隔离分为4个级别
1.read uncommit (读未提交),存在脏读、不可重复度问题、幻读
2.read commit (读已提交),存在不可重复读、幻读
3.repeatable read(可重复读),存在幻读
4.serialable(串行化),没有上面的问题,但性能过低
mysql,默认使用 rr 级别,它通过 mvvc 解决可重复读问题 ,通过 next-key 解决了幻读的问题,next-key 包含 记录锁和 间隙锁
关于 mysql 锁可以参考这篇文章
https://www.linuxidc.com/Linux/2018-11/155501.htm
来源:oschina
链接:https://my.oschina.net/haitaohu/blog/3153443