MySQL 事务管理


重点: begin/start transaction 命令并不是一个事务的起点,在执行到它们之后的 第一个操作 InnoDB 表的语句,事务才真正启动。如果想要马上启动一个事务,可以使用 start transaction with consistent snapshot 这个命令。

事务隔离级别

根据读和提交的关系来分类的

  • 读未提交:一个事务还没提交时,它做的变更就能被别的事务看到;
  • 读提交:一个事务提交之后,能被其他事务看到;
  • 可重复读:一个事务执行过程中看到的数据,总是根这个事务在启动时看到的数据一致;
  • 串行化:同时加上“读锁”和“写锁”,后访问的事务必须等前一个事务执行完成,才能继续执行。

读提交与可重复读对比

https://blog.csdn.net/java_collect/article/details/105042975

  1. 在RR隔离级别下,存在间隙锁,导致出现死锁的几率比RC大的多!
  2. 在RR隔离级别下,条件列未命中索引会锁表!而在RC隔离级别下,只锁行
  3. 在RC隔离级别下,引入半一致性读(semi-consistent)特性增加了update操作的性能

半一致性读:一个update语句,如果读到一行已经加锁的记录,此时InnoDB返回记录最近提交的版本,由MySQL上层判断此版本是否满足update的where条件。若满足(需要更新),则MySQL会重新发起一次当前读操作,叫做半一致性读是因为 MVCC 用于满足一致性,而 update 则破坏了这种特性使用当前读。

MySQL使用可重复读作为默认隔离级别的原因

https://blog.csdn.net/java

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值