验证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; -- 提交后数据持久化,对其他会话可见

相关推荐
志栋智能32 分钟前
超自动化安全:构建智能安全运营的核心引擎
大数据·运维·服务器·数据库·安全·自动化·产品运营
zhoutongsheng1 小时前
C#怎么实现Swagger文档 C#如何在ASP.NET Core中集成Swagger自动生成API文档【框架】
jvm·数据库·python
WinterKay2 小时前
【开源】我写了一个轻量级本地数据库浏览工具,支持 MySQL/Redis 只读查询
数据库·mysql·开源
zxrhhm3 小时前
Oracle 索引完整指南
数据库·oracle
程序猿乐锅3 小时前
【Tilas|第三篇】多表SQL语句
数据库·经验分享·笔记·学习·mysql
Navicat中国4 小时前
使用 Navicat 导入向导导入 Excel 数据时,系统提示导入成功,表中也能看到数据,但行数统计显示为 0,这是什么原因?
数据库·excel·导入
gmaajt5 小时前
Golang怎么做国际化多语言_Golang i18n教程【核心】
jvm·数据库·python
折哥的程序人生 · 物流技术专研5 小时前
从“卡死”到“秒过”:WMS销售数据跨库回填的极限优化之旅
数据库·机器学习·oracle
李可以量化5 小时前
DeepSeek 量化交易实战:用标准化提示词模板实现 AI 辅助交易决策
大数据·数据库·人工智能
maqr_1105 小时前
CSS如何利用Sass定义全局阴影方案_通过变量实现统一CSS风格
jvm·数据库·python