-- 创建测试表 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)
登录后复制