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

【面试干货】事务的并发问题(脏读、不可重复读、幻读)与解决策略

【面试干货】事务的并发问题(脏读、不可重复读、幻读)与解决策略

  • 一、脏读(Dirty Read)
  • 二、不可重复读(Non-repeatable Read)
  • 三、幻读(Phantom Read)
  • 四、总结


💖The Begin💖点点关注,收藏不迷路💖

在数据库管理系统(DBMS)中,事务的并发执行是提高系统性能的关键。然而,并发执行也带来了一系列的问题,如 脏读、不可重复读和幻读。本文将详细解释这些并发问题,并探讨相应的解决策略。

一、脏读(Dirty Read)

1、定义

脏读是指一个事务读取了另一个事务尚未提交的数据。由于被读取的数据可能由于某些原因被回滚,因此该数据是“脏”的,即不可靠 的。

2、示例

假设 事务A读取了事务B尚未提交的对某个数据行的修改,随后事务B发生错误并执行了回滚操作。此时,事务A读取到的数据就是脏数据,因为它已经不再是数据库中的当前状态

3、解决策略

为了避免脏读,DBMS采用了隔离级别的概念。通过设置不同的隔离级别,可以控制事务之间的可见性。例如,在 可重复读(Repeatable Read)或串行化(Serializable) 隔离级别下,事务只能读取已经提交的数据,从而避免了脏读。

二、不可重复读(Non-repeatable Read)

1、定义

不可重复读 是指在一个事务内,多次读取同一数据,但由于其他事务的修改并提交,导致该事务先后读取到的数据结果不一致。

2、示例

假设事务A两次读取同一数据行,在两次读取之间,事务B修改了该数据行并提交。此时,事务A第二次读取到的数据与前一次不同,即发生了不可重复读

3、解决策略

为了解决不可重复读问题,DBMS同样采用了隔离级别的概念。在 可重复读(Repeatable Read)或串行化(Serializable) 隔离级别下,事务在开始时会获取一个数据快照,并在整个事务过程中始终基于该快照进行读取操作,从而保证了多次读取结果的一致性

三、幻读(Phantom Read)

1、定义

幻读 是指在一个事务内,执行相同的查询操作,但由于其他事务的插入或删除操作并提交,导致该事务两次查询到的结果集不一致

2、示例

假设事务A执行了一个范围查询(如查询年龄大于20且小于30的所有用户),在查询结果返回后,事务B插入了一个年龄为25的新用户并提交此时,如果事务A再次执行相同的范围查询,会发现新的用户记录“凭空出现”了,即发生了幻读

3、解决策略

幻读 的解决策略通常依赖于特定的数据库管理系统和隔离级别。在 串行化(Serializable) 隔离级别下,DBMS会 通过加锁等机制来防止其他事务的插入或删除操作,从而避免了幻读。此外,一些数据库管理系统还提供了特定的查询选项或语句来避免幻读。

如: 使用SELECT … FOR UPDATE语句来锁定查询结果集中的所有行。

四、总结

事务的并发执行是数据库管理系统提高性能的重要手段,但同时也带来了一系列并发问题。通过合理设置隔离级别和采用相应的解决策略,我们可以有效地避免脏读、不可重复读和幻读等并发问题,确保数据库的一致性和可靠性。

在这里插入图片描述


💖The End💖点点关注,收藏不迷路💖
http://www.lryc.cn/news/357261.html

相关文章:

  • 函数式接口:现代编程的利器
  • 2022职称继续教育--深入实施新时代人才强国战略 加快建设世界重要人才中心和创新高地
  • kube-prometheus-stack 识别 k8s 集群内所有的 ServiceMonitor 和 PrometheusRule
  • Android 图片加载glide库 一次通关
  • Spring OAuth2:开发者的安全盾牌!(上)
  • 设计模式使用(成本扣除)
  • 输入输出(2)——C++的标准输出流
  • C语言序列化和反序列化--TPL(一)
  • Session + JWT + Cookie
  • PaddleOCR2.7+Qt5
  • 在Android中解析XML文件并在RecyclerView中显示
  • Notes for video: EDC-Con 2022/01 - EDC Conceptual Overview and Architecture
  • windows下nginx配置https证书
  • Llama改进之——RoPE旋转位置编码
  • Python的解析网页
  • VBA技术资料MF159:实现某个区域内的数据滚动
  • 开源DMS文档管理系统 Nuxeo Vs Alfresco对比及 API 使用概述
  • lambda函数实践
  • [leetcode hot 150]第一百九十一题,位1的个数
  • gitea的git库备份与恢复
  • 【强化学习05】从Q学习到深度Q学习
  • FPGA实现多路并行dds
  • ArcgisPro3.1.5安装手册
  • 三大主流框架
  • 【C++】:vector容器的底层模拟实现迭代器失效隐藏的浅拷贝
  • 必看项目|多维度揭示心力衰竭患者生存关键因素(生存分析、统计检验、随机森林)
  • centos安装Redis
  • 继承与多态2
  • 在RT-Thread下为MPU手搓以太网MAC驱动-3
  • Cocos Creator 2D物理引擎的使用详解