深入解析MySQL MVCC 原理与实现

深入解析MySQL MVCC 原理与实现

发布:admin2024-03-27 10:43分类:数据库标签:深入解析MySQL MVCC 原理与实现

-- 创建测试表
CREATE TABLE `student` (
  `id` INT NOT NULL AUTO_INCREMENT,
  `name` VARCHAR(50) NOT NULL,
  `age` INT NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB;

-- 插入测试数据
INSERT INTO student (name, age) VALUES ('Alice', 20), ('Bob', 21);

-- 打开事务1,插入一条数据
START TRANSACTION;
INSERT INTO student (name, age) VALUES ('Charlie', 22);

-- 打开事务2,读取数据,此时只能看到事务1之前的数据
START TRANSACTION;
SELECT * FROM student;
-- 输出:(1, 'Alice', 20), (2, 'Bob', 21)

-- 提交事务1,释放事务1深入解析MySQL MVCC 原理与实现的锁
COMMIT;

-- 在事务2中再次读取
SELECT * FROM student;
-- 输出:(1, 'Alice', 20), (2, 'Bob', 21), (3, 'Charlie', 22)

-- 关闭事务2
COMMIT;

-- 删除数据,实际上是生成一个删除标记
START TRANSACTION;
DELETE FROM student WHERE id = 2;

-- 打开事务3,读取数据,此时只能看到事务3之前的数据
START TRANSACTION;
SELECT * FROM student;
-- 输出:(1, 'Alice', 20), (3, 'Charlie', 22)

-- 提交事务3,数据行被删除
COMMIT;

-- 在事务4中再次读取
SELECT * FROM student;
-- 输出:(1, 'Alice', 20), (3, 'Charlie', 22)
登录后复制
温馨提示如有转载或引用以上内容之必要,敬请将本文链接作为出处标注,谢谢合作!

发表评论

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

欢迎使用手机扫描访问本站,还可以关注微信哦~