五分钟搞清楚 MVCC 机制:https://juejin.im/post/6844903778026536968
当前读
需要加锁,select * for unpdate 等
快照读
读取的是快照,不需要加锁,其他事物对此快照内存不受影响,其实得力于mvcc的版本控制
MySQL-当前读、快照读、MVCC
前言:事务的开启与提交模式
对于一个MYSQL数据库(InnoDB),事务的开启与提交模式无非下面这两种情况:
- 若参数autocommit=0,事务则在用户本次对数据进行操作时自动开启,在用户执行commit命令时提交,用户本次对数据库开始进行操作到用户执行commit命令之间的一系列操作为一个完整的事务周期。若不执行commit命令,系统则默认事务回滚。总而言之,当前情况下事务的状态是自动开启手动提交。
- 若参数autocommit=1(系统默认值),事务的开启与提交又分为两种状态:
①手动开启手动提交:当用户执行start transaction命令时(事务初始化),一个事务开启,当用户执行commit命令时当前事务提交。从用户执行start transaction命令到用户执行commit命令之间的一系列操作为一个完整的事务周期。若不执行commit命令,系统则默认事务回滚。
②自动开启自动提交&