文章目录
重点:
begin/start transaction
命令并不是一个事务的起点,在执行到它们之后的
第一个操作
InnoDB
表的语句,事务才真正启动。如果想要马上启动一个事务,可以使用
start transaction with consistent snapshot
这个命令。
事务隔离级别
根据读和提交的关系来分类的
- 读未提交:一个事务还没提交时,它做的变更就能被别的事务看到;
- 读提交:一个事务提交之后,能被其他事务看到;
- 可重复读:一个事务执行过程中看到的数据,总是根这个事务在启动时看到的数据一致;
- 串行化:同时加上“读锁”和“写锁”,后访问的事务必须等前一个事务执行完成,才能继续执行。
读提交与可重复读对比
https://blog.csdn.net/java_collect/article/details/105042975
- 在RR隔离级别下,存在间隙锁,导致出现死锁的几率比RC大的多!
- 在RR隔离级别下,条件列未命中索引会锁表!而在RC隔离级别下,只锁行
- 在RC隔离级别下,引入半一致性读(
semi-consistent
)特性增加了update操作的性能
半一致性读:一个update语句,如果读到一行已经加锁的记录,此时InnoDB返回记录最近提交的版本,由MySQL上层判断此版本是否满足update的where条件。若满足(需要更新),则MySQL会重新发起一次当前读操作,叫做半一致性读是因为 MVCC 用于满足一致性,而 update 则破坏了这种特性使用当前读。