mysql 事务隔离级别如何选择

半腔热情 提交于 2020-01-07 01:02:31

【推荐】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

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!