当前位置: 首页 > news >正文

脏读、不可重复读、幻读示例

1. 脏读 (Dirty Read)

场景:事务A读取了事务B未提交的数据修改。

-- 事务A
BEGIN TRANSACTION;
UPDATE accounts SET balance = balance - 100 WHERE id = 1; -- 账户1扣除100元,未提交-- 事务B
BEGIN TRANSACTION;
SELECT balance FROM accounts WHERE id = 1; -- 读取到未提交的修改(脏读)
COMMIT;-- 事务A
ROLLBACK; -- 事务A回滚,但事务B已经读取了错误的数据

2. 不可重复读 (Non-repeatable Read)

场景:同一事务内两次读取同一数据,结果不同。

-- 事务A
BEGIN TRANSACTION;
SELECT balance FROM accounts WHERE id = 1; -- 第一次读取,返回1000-- 事务B
BEGIN TRANSACTION;
UPDATE accounts SET balance = balance - 100 WHERE id = 1;
COMMIT;-- 事务A
SELECT balance FROM accounts WHERE id = 1; -- 第二次读取,返回900(与第一次不同)
COMMIT;

3. 幻读 (Phantom Read)

场景:同一事务内两次查询同一条件,返回的行数不同。

-- 事务A
BEGIN TRANSACTION;
SELECT * FROM accounts WHERE balance > 1000; -- 第一次查询返回2条记录-- 事务B
BEGIN TRANSACTION;
INSERT INTO accounts(id, balance) VALUES (3, 1500); -- 新增一个高余额账户
COMMIT;-- 事务A
SELECT * FROM accounts WHERE balance > 1000; -- 第二次查询返回3条记录(出现幻行)
COMMIT;

隔离级别与这些问题

隔离级别脏读不可重复读幻读
READ UNCOMMITTED可能可能可能
READ COMMITTED避免可能可能
REPEATABLE READ避免避免可能
SERIALIZABLE避免避免避免
http://www.dtcms.com/a/166276.html

相关文章:

  • Clang-Tidy协助C++编译期检查
  • 在Windows系统上如何用Manifest管理嵌入式项目
  • 《Python实战进阶》No45:性能分析工具 cProfile 与 line_profiler
  • 架构进阶:72页集管IT基础设施蓝图设计方案【附全文阅读】
  • 软考中级-软件设计师 数据库(手写笔记)
  • 算法-冒泡排序
  • Ecology中拦截jquery.ajax请求接口后的数据
  • 【免费数据】2000-2020年中国4km分辨率逐日气象栅格数据(含9个气象变量)
  • windows11 编译 protobuf-3.21.12 c++
  • 大连理工大学选修课——机器学习笔记(4):NBM的原理及应用
  • 机器学习|通过线性回归了解算法流程
  • 制作一款打飞机游戏35:生成系统
  • YOLO视觉模型可视化训练与推理测试工具
  • 分享高德地图获取矢量面的方法和python脚本
  • BI平台是什么意思?一文讲清BI平台的具体应用!
  • 线性微分方程与非线性微分方程
  • Windows查看和修改IP,IP互相ping通
  • 智能机器人在物流行业的应用:效率提升与未来展望
  • 【QT】编写第一个 QT 程序 对象树 Qt 编程事项 内存泄露问题
  • 【SystemC初认识】SystemC是什么?有哪些主要组件?如何简单使用?
  • Java高阶程序员学习计划(详细到天,需有一定Java基础)
  • TimeDistill:通过跨架构蒸馏的MLP高效长期时间序列预测
  • LeRobot 项目部署运行逻辑(四)——control_robot.py
  • 使用 Spring Data Redis 实现 Redis 数据存储详解
  • L35.【LeetCode题解】转置矩阵(C语言)
  • 11.Spring Boot 3.1.5 中使用 SpringDoc OpenAPI(替代 Swagger)生成 API 文档
  • 2025.4.28 Vue.js 学习笔记
  • Rancher 2.6.3企业级容器管理平台部署实践
  • 百家号等新媒体私信入口是否可以聚合到企业微信的客服,如何实现
  • E. Unpleasant Strings【Educational Codeforces Round 178 (Rated for Div. 2)】