当前位置: 首页 > 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避免避免避免

相关文章:

  • 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是什么?有哪些主要组件?如何简单使用?
  • 黄育奇当选福建惠安县人民政府县长
  • 融创服务全面退出彰泰服务集团:约8.26亿元出售广西彰泰融创智慧80%股权
  • 78家公募年度业绩比拼:23家营收净利双升,十强座次微调
  • 这就是上海!
  • 神十九飞船已撤离空间站,计划于今日中午返回东风着陆场
  • 交行一季度净利253.72亿元增1.54%,不良率微降