前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >mysql 事务隔离级别如何选择

mysql 事务隔离级别如何选择

作者头像
海涛
发布2020-01-15 17:08:23
1.5K0
发布2020-01-15 17:08:23
举报
文章被收录于专栏:海涛技术日常海涛技术日常

四个概念:

数据丢失、脏读、不可重复读、幻读

数据丢失,两个事务同时进行,一个成功一个失败,造成数据回滚,或者两个都成功造成数据覆盖

从这个概念,就可以看出事务隔离的必要性,如果没有的话很容易产生这个严重的问题

脏读:在一个事务里面,读取到另一个事务还没提交的数据

不可重复读:一个事务内两次读同一个数据,可能发生变化(一般指该数据事务期间被别的事务修改,理解对一条数据操作)

幻读:一个事务内两次查询数据不一致(条件查询,理解多条数据,其他事务有新增或者删除)

事务隔离分为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

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档