1)并发事务的问题

news/2024/7/8 6:33:29 标签: 数据库

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.niftyadmin.cn/n/5536622.html

相关文章

Ruby 环境变量

Ruby 环境变量 概述 环境变量在编程中扮演着重要的角色,尤其是在Ruby这样的动态编程语言中。它们是操作系统用来存储有关其操作环境的信息的变量,可以在程序运行时影响其行为。Ruby程序可以通过环境变量来获取配置信息、系统细节或用户特定的设置。本文将深入探讨Ruby中环境…

数据资产赋能企业决策:通过精准的数据分析和洞察,构建高效的数据资产解决方案,为企业提供决策支持,助力企业实现精准营销、风险管理、产品创新等目标,提升企业竞争力

一、引言 在信息化和数字化飞速发展的今天,数据已成为企业最宝贵的资产之一。数据资产不仅包含了企业的基本信息,还蕴含了丰富的市场趋势、消费者行为和潜在商机。如何通过精准的数据分析和洞察,构建高效的数据资产解决方案,为企…

数据结构第08小节:双端队列

双端队列(deque,double-ended queue)是一种具有队列和栈特性的数据结构,允许在其两端进行插入和删除操作。在Java中,java.util.Deque接口就是双端队列的实现,而ArrayDeque和LinkedList是其中的具体实现类。…

电容的作用和应用

电容是一种常见的电子元件,在电路中起着多种重要作用,并广泛应用于各种电子设备和系统中。 一、电容的主要作用 储能:电容的基本作用是储存电荷。当电容两端加上电压时,电容会储存电荷,储存的电荷量与电压成正比。这…

直播视频怎么录制?让你秒变录制达人

随着直播行业的蓬勃发展,越来越多的人开始参与到直播中,分享自己的生活、技能与见解。然而,在直播过程中,有时我们希望能够记录下精彩的瞬间,或是将整个直播内容保存下来以供日后回顾或分享。可是直播视频怎么录制呢&a…

纯前端低代码开发脚手架 - daelui/molecule

daelui/molecule低代码开发脚手架:分子组件开发、预览、打包 页面代码示例、大屏代码示例预览 可开发页面组件 可开发大屏组件 项目git地址:https://gitee.com/daelui/molecule 在线预览:http://www.daelui.com/daelui/molecule/app/index.…

Docker-自定义镜像发布到DockerHub仓库、阿里云仓库

文章目录 推送镜像DockerHub仓库推送镜像阿里云仓库 更多相关内容可查看 推送镜像DockerHub仓库 在服务器中 使用 docker 登录命令 docker login -u 账户 #enter 后输入密码推送镜像到DockerHub docker push 镜像名:tag但个人不建议推送到DockHub上,毕竟不是咱自…

Codeforces 220B

传送门 题目大意 给出一个长度为 n n n的序列,进行 m m m次询问。 每次询问区间 [ l , r ] [l,r] [l,r]内,有多少个数字 x x x刚好出现了 x x x次。 思路 枚举右端点 r r r,维护左端点 l l l,设法将 s u m ( l , r ) s u m (…