验证mysql RR隔离水平,并未完全实现防止幻读的实验

-- ==============================================

-- 会话A - 幻读实验主事务(整段复制,按执行提示分步跑)

-- ==============================================

-- 1. 环境准备:删旧表+建测试表+关自动提交+确认隔离级别

DROP TABLE IF EXISTS test_phantom;

CREATE TABLE test_phantom (id INT PRIMARY KEY, name VARCHAR(20) NOT NULL) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

SET SESSION autocommit = 0;

SELECT @@transaction_isolation AS '当前隔离级别'; -- 预期结果:REPEATABLE-READ

-- 2. 启动事务+首次快照读(创建ReadView,核心步骤)

START TRANSACTION;

SELECT * FROM test_phantom WHERE id=1; -- 预期结果:空集(表无数据)

-- ========== 到此为止!先停在这里,切换到【会话B】执行完所有代码,再切回A继续下面的步骤 ==========

-- 3. 二次快照读(复用ReadView,依然读不到数据,RR纯快照读特性)

SELECT * FROM test_phantom WHERE id=1; -- 预期结果:还是空集(没幻读,防住了纯快照读)

-- 4. 执行UPDATE当前读(绕开ReadView,抓取会话B提交的最新数据)

UPDATE test_phantom SET name='innodb_phantom' WHERE id=1; -- 预期结果:Rows matched:1 Changed:1(执行成功)

-- 5. 三次快照读(幻读出现!同一事务相同查询,从空变有)

SELECT * FROM test_phantom WHERE id=1; -- 预期结果:(1, 'innodb_phantom') 【核心幻读现象】

-- 6. 提交事务,结束实验

COMMIT;

-- ==============================================

-- 会话B - 插入数据并提交(整段复制,直接全跑)

-- ==============================================

-- 环境准备:仅关闭自动提交即可(表由会话A创建,无需重复建)

SET SESSION autocommit = 0;

-- 插入id=1数据并立即提交(数据对外可见,触发幻读的前提)

START TRANSACTION;

INSERT INTO test_phantom VALUES (1, 'mysql_rr'); -- 预期结果:插入成功,影响行数1

COMMIT; -- 提交后数据持久化,对其他会话可见

相关推荐
jiayou6415 小时前
KingbaseES 表级与列级加密完全指南
数据库·后端
GBASE1 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr2 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
吃糖的小孩3 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
笃行3504 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3504 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3504 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
SelectDB4 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
这个DBA有点耶5 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构