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

相关推荐
胜天半月子13 分钟前
性能测试 | 性能测试工具JMeter直连数据库和逻辑控制器的使用
数据库·测试工具·jmeter·性能测试
weixin_466815 分钟前
Redis主从复制
数据库·redis·缓存
小丁爱养花27 分钟前
Redis - hash & list (常用命令/内部编码/应用场景)
数据库·redis·哈希算法
半路_出家ren1 小时前
图书销售系统数据库设计方案
数据库·mysql·子查询·ddl·dml·数据库设计·分组查询
自由会客室1 小时前
Ubuntu24.04
数据库·postgresql
ayaya_mana2 小时前
MySQL忘记Root密码,详细找回密码步骤
数据库·mysql·adb
顾三殇2 小时前
【MySQL】win 10 / win11:mysql 5.7 下载、安装与配置
数据库·mysql
言之。2 小时前
Django `select_related` 查询优化
数据库·django·sqlite
潜心编码2 小时前
基于Django的医疗电子仪器系统
前端·数据库·1024程序员节
芙蓉王真的好12 小时前
Django 新手常见错误:模板找不到、数据库连接失败的解决办法
数据库·django·sqlite