mysql事务隔离级别选择_mysql事务隔离级别如何选择

四个概念:

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

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

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

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

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

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

事务隔离分为4个级别

1.read uncommit (读未提交),存在脏读、不可重复度问题、幻读

2.read commit (读已提交),存在不可重复读、幻读

3.repeatable read(可重复读),存在幻读

4.serialable(串行化),没有上面的问题,但性能过低

mysql,默认使用 rr 级别,它通过 mvvc 解决可重复读问题 ,通过 next-key 解决了幻读的问题,next-key 包含 记录锁和 间隙锁

关于 mysql 锁可以参考这篇文章

文章来源: www.oschina.net,作者:小海bug,版权归原作者所有,如需转载,请联系作者。

原文链接:https://my.oschina.net/haitaohu/blog/3153443

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值