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

1)并发事务的问题

1) 并发事务的问题?

(1)读“脏”数据

事务T1修改数据后T2读取了该数据,但是T1撤消了修改,
事务T1进行了回滚,导致事务T2读取的数据与数据库中的数据不一致。

(2)丢失修改

两个事务读入同一数据并修改,T2的提交结果破坏了T1提交的结果。

(3)不可重复读

事务T1读取数据后,事务T2修改数据并提交结果破坏了T1的提交结果,T1无法再现前一次的读取结果。

(4)幻读

事务T1读取几行数据后,事务T2插入或删除了一些数据,T1再次查询中会发现多/少了一些数据。

并发控制的主要技术:

  • 封锁(Locking)
    封锁是最常见的并发控制机制。锁可以分为排他锁(X锁)和共享锁(S锁)。X锁不允许其他任何事务读或写数据,而S锁允许其他事务读数据但不能写。

  • 时间戳(Timestamp)
    时间戳机制:每个事务开始时都会被分配一个时间戳。当事务尝试读取或写入数据时,会检查数据上的时间戳并确定是否发生冲突。如果时间戳较新,则事务可以继续;否则,事务可能需要回滚或重试。

  • 乐观控制法(Optimistic Concurrency Control, OCC)
    OCC假设冲突较少,允许事务在没有锁的情况下运行,直到事务提交时才检查是否有冲突。如果检测到冲突,事务将被回滚并重新开始

  • 多版本并发控制法(multi-version concurrency control,MVCC)

关于MVCC可以看一下这篇博文:https://huaweicloud.csdn.net/63354fc7d3efff3090b53e5e.html

http://www.lryc.cn/news/391754.html

相关文章:

  • Python缓存利器:cachetools库详解
  • 【Python实战因果推断】20_线性回归的不合理效果10
  • 在Ubuntu 16.04上安装和配置ownCloud的方法
  • Java | Leetcode Java题解之第213题打家劫舍II
  • 使用 ESP32 接收 MAX4466 模拟麦克风模块的数据,通过 DAC 转码成 PCM 格式,并通过 MQTT 发送给另一台设备,可以通过以下步骤实现。
  • SQL二次注入原理分析
  • 在线签约如何选择?2024年10款顶级app大比拼
  • gcc: warning: -Wunused-function;加了选项,为什么就不报警告呢?
  • 系统提示我未定义与 ‘double‘ 类型的输入参数相对应的函数 ‘finverse‘,如何解决?
  • 【电路笔记】-B类放大器
  • Ubuntu 22.04 安装中文字体
  • 「树莓派入门」树莓派进阶04-直流电机控制与PWM应用
  • 利用数据集,用机器学习模型对股市预测,聊聊看!
  • 015-GeoGebra基础篇-定点旋转物体、动态显示数值并显示运动轨迹
  • 2024年6月份找工作和面试总结
  • 同步时钟:北斗/GPS卫星、电信基站、NTP以太网校时方式的区别
  • 实现Java应用的快速开发与迭代
  • 利用redis数据库管理代理库爬取cosplay网站-cnblog
  • 数据仓库建模基础理论-01-为什么需要数据建模?
  • 中序遍历的两种实现——二叉树专题复习
  • python 基础综合应用——小开发
  • 算法金 | 我最常用的两个数据可视化软件,强烈推荐
  • 【机器学习实战】Baseline精读笔记
  • Redis 缓存问题及解决
  • RISC-V的历史与设计理念
  • 山西车间应用LP-LP-SCADA系统的好处有哪些
  • setjmp和longjmp函数使用
  • vue-org-tree搜索到对应项高亮展开
  • FullCalendar日历组件集成实战(17)
  • 【图像分割】mask2former:通用的图像分割模型详解