Oracle 中的并发更新:锁定与否?

2024-02-22

我很困惑。我正在阅读有关 Oracle 中的 MVCC 的内容。我以为MVCC意味着没有锁。但是,我在其他地方读到这一切UPDATE无论隔离级别如何,都会执行自动锁定。有人可以解释一下 Oracle 更新期间会发生什么吗?当多个已提交读事务尝试并发执行时会发生什么update t set c = c + 1 where id = 3。假设在任一事务之前 c = 1,结果是什么?锁和 SCN 发生了什么?

Begin T1
Begin T2
T1:  update t set c = c + 1 where id = 3
T2:  update t set c = c + 1 where id = 3
Commit T1
Commit T2

你是对的,无论隔离级别如何,这都会锁定该行。使用MVCC,您可以在没有锁的情况下获得一致的读取,但在写入时仍然需要锁。

第二个事务将等待第一个事务完成(例如:COMMIT or ROLLBACK)在尝试做任何事情之前。因此,在这种情况下,T2 上的光标将“挂起”在更新上,等待 T1 完成。

T1 提交后您将获得一个新的 SCN,T2 提交后您将获得另一个 SCN。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Oracle 中的并发更新:锁定与否? 的相关文章

随机推荐

  • 如何理解以下多维数组的奇特索引行为?

    我们注意到 对于多维数组来说 花式索引和切片的混合使用非常令人困惑且没有记录 例如 In 114 x np arange 720 reshape 2 3 4 5 6 In 115 x 0 0 1 2 4 5 shape Out 115 2
  • 将套接字绑定到网络接口

    如何将套接字绑定到特定的网络接口 我尝试使用setsockopt在服务器端 但客户端仍然可以通过 eth0 和 lo 接口访问服务 我可以通过使用设置特定的IP地址来实现这一点serv addr sin addr s addr 但我怀疑我们
  • 从代码加载 WPF 中的图像

    我一定在网上阅读了大量的解决方案 但由于某种愚蠢的原因我无法让它们工作 我的项目的 Resources 文件夹中有一个 jpg 图像 该图像设置为 构建操作 资源 不是嵌入资源 并且从不复制到输出文件夹 我的形象是not添加到我的 reso
  • EditText - 如何分隔在组或块中在 EditText 中键入的字符

    有没有一种方法可以在用户打字时将 EditText 中的字符分组到块中 示例 1234 4567 7890等等 我有一个支持数字且长度为 16 个字符的编辑文本 我想将它们分组在单独的块中以获得更好的可见性 editText addText
  • 现代版本的 WinDiff? [关闭]

    Closed 这个问题正在寻求书籍 工具 软件库等的推荐 不满足堆栈溢出指南 help closed questions 目前不接受答案 VB6附带WinDiff 是否有免费的现代版本的 WinDiff 可以忽略大小写 除了最新 SDK 中
  • 使用PL/SQL删除大量记录

    我想使用PL SQL删除大量记录 这些记录由 DATE 字段标识 该字段标识上次修改记录的时间 我不想消耗太多资源 因此我认为应该限制要删除的记录数量 在我看来 伪列 ROWNUM 可以满足此目的 然后 我检查受更新影响的行数并重复 直到影
  • 是否可以对 Websocket 升级请求使用承载身份验证?

    打开WebSocket连接的升级请求是标准的HTTP请求 在服务器端 我可以像其他任何请求一样验证请求 就我而言 我想使用承载身份验证 不幸的是 在浏览器中打开 Websocket 连接时无法指定标头 这会让我相信不可能使用承载身份验证来验
  • 使用 sleep 和 wait -n 在 bash 中实现简单的超时,是否存在竞争条件?

    如果我在 bash 脚本中执行此操作 sleep 10 sleep pid some command wait n cmd pid if kill 0 sleep pid 2 gt dev null then all ok kill sle
  • 如何等待 ThreadPoolExecutor 中的所有任务完成而不关闭 Executor?

    我不能使用shutdown and awaitTermination 因为在等待时 新任务可能会被添加到 ThreadPoolExecutor 中 因此 我正在寻找一种方法来等待 ThreadPoolExecutor 清空其队列并完成所有任
  • 如何使用BetterAuthorizationSample? - 可可

    我正在尝试使用 BetterAuthorizationSample 而不是采用所谓的 恶意 方式使用 setuid 来获取 root 权限 目前我正在使用 AuthorizationCreate 使用 BLAuthentication 获得
  • 使用 docker 和主机文件

    我正在尝试让 hbase 容器运行 并且该容器需要一些stuff这意味着 docker 主机需要作为 docker 可用 我们通过使用 docker 在主机文件中设置 docker ip 来实现这一点 但是 当我运行时 docker ps
  • 获取当前语言 next-i18next

    我将 NextJS 与 next i18next 一起使用 这是我的主页 import withTranslation from config next i18next const Home function Home return div
  • 尝试在 google chrome 中使用 HTML5 文件 api 时出现 FileError

    我试图使用 chrome 中的文件系统 API 创建一个文件 最初我尝试了如下持久存储 window requestFileSystem window requestFileSystem window webkitRequestFileSy
  • 使用 distplot 绘制直方图时 y 轴的单位是什么?

    使用 distplot 绘制直方图时 y 轴的单位是什么 我用正常拟合绘制了不同的直方图 我发现在一种情况下 它的范围是 0 到 0 9 而在另一种情况下 它的范围是 0 到 4 5 From help sns distplot norm
  • 为什么函数调用称为“函数调用”?

    我知道什么是函数调用 我知道它的作用 我已经调试了很多了 我有some凭直觉理解为什么使用术语 函数调用 是有意义的 但归根结底 我无法像使用 函数调用 那样正确解释这一点return陈述 例如 用return陈述答案是 叫做 回归 因为你
  • 如何通过“合并前需要拉取请求审查”来保护分支

    我已将其发布在 github community 上 但尚未得出任何解决方案 我试图保护主分支免受单人直接推送的影响 每个更改都必须通过 功能 分支进行 然后通过拉取请求得到另一个 或特定 开发人员的批准 在存储库的设置中 此功能似乎可以执
  • tf.data.Iterator.get_next():如何在tf.while_loop中前进?

    目前 我尝试在 Tensorflow while 循环中实现所有训练 但我在使用 Tensorflow 数据集 API 的迭代器时遇到了问题 通常 当调用 sess run 时 Iterator get next 前进到下一个元素 但是 我
  • 使用 Dozer 的自定义转换器将对象列表映射到另一个列表

    我想做的是使用 Dozer 将实体列表映射到它们的字符串 ID 列表 或多或少 显然 它意味着自定义转换器 我的第一个想法是创建一个从 MyEntity 到 String 的转换器 然后对 Dozer 说 使用此转换器映射此集合的每个对象
  • 获取 foreach 中先前的数组值

    我的数组 arr array jan feb mar apr mei jun jul agu sep okt nov des 然后我做了一个 foreach foreach arr as ar echo ar 这会将 jan 输出到 des
  • Oracle 中的并发更新:锁定与否?

    我很困惑 我正在阅读有关 Oracle 中的 MVCC 的内容 我以为MVCC意味着没有锁 但是 我在其他地方读到这一切UPDATE无论隔离级别如何 都会执行自动锁定 有人可以解释一下 Oracle 更新期间会发生什么吗 当多个已提交读事务