没有索引时,FOR UPDATE 会锁住整个表

现在,你正在一本一本地翻看所有书,寻找“维修中”的书,并且你对管理员说:“在我清点和修改完之前,别人不能动这些书,也不能往这个范围里加新书!

  • 问题1:如何锁住你找到的“维修中”的书?
    你每找到一本“维修中”的书,就给它贴上一个“正在处理,请勿触碰”的标签(行级排他锁)。

  • 问题2:如何防止别人“往这个范围里加新书”?
    这是最关键的。因为你没有“状态”的目录卡片(没有索引),你不知道“维修中”的书在图书馆的哪个具体位置。它们可能散落在图书馆的任何角落。

    • 你无法像有索引那样,只锁住“计算机类”书架的某个空位(间隙锁)。
    • 你正在全图书馆地毯式搜索。
    • 如果允许其他管理员在你搜索的时候,随便往任何一个空书架上放一本新的“维修中”的书,那么你就会遇到“幻读”——你清点完后,发现多出了几本你没见过的“维修中”的书。

唯一的办法就是:

为了确保在你搜索和处理期间,没有任何新的“维修中”的书被偷偷放进来,图书馆管理员只能宣布:

“暂停营业!所有人都不能动任何书,也不能放新书进来,直到这位管理员清点完毕!”

这就是表级排他锁。它锁住了整个图书馆,确保了在你操作期间,没有任何新的“维修中”的书能够被插入,从而彻底避免了幻读。

总结一下:

WHERE 条件中的字段没有索引时,数据库无法精确地定位和锁定数据范围。为了满足 FOR UPDATE 语句防止幻读的要求,它不得不采取最保守、最安全的策略——锁定整个表。这就像为了防止一只老鼠跑进屋子,你把整个房子的大门都锁死了。虽然有效,但代价是牺牲了其他人的自由(并发性)。

所以,为了提高数据库的效率和并发性,对于那些经常用于 WHERE 条件,特别是用于 FOR UPDATE 的字段,强烈建议创建索引。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/88441.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/88441.shtml
英文地址,请注明出处:http://en.pswp.cn/bicheng/88441.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

TCP-与-UDP-协议详解:原理、区别与应用场景全解析

TCP 与 UDP 协议详解:原理、区别与应用场景全解析 在日常使用网络的过程中,我们经常听到 TCP 和 UDP 这两个词。你打开网页、发送消息、观看视频,背后都在使用 TCP 或 UDP 进行数据传输。那么这两个协议到底是怎么工作的?它们之间…

GitHub信息收集

目录 简介 一、入门搜索技巧 1. 基本关键词搜索 2. 文件类型限定搜索 3. 用户/组织定向搜索 二、精准定位技巧 1. 组合搜索条件 2. 排除干扰结果 3. 路径限定搜索 三、防御建议 四、法律与道德提醒 简介 GitHub作为全球最大的代码托管平台,存储着数十亿…

由 DB_FILES 参数导致的 dg 服务器无法同步问题

由 DB_FILES 参数导致的 dg 服务器无法同步问题 用户反映,dg 服务器数据从昨晚(7月8日)开始停止同步。 连接服务器发现没有 mrp 进程,并且 OPEN_MODE 参数也不正确。具体情况如下所示: SQL> select process, status…

Go语言泛型-泛型对代码结构的优化

在Go语言中,Go泛型-泛型对代码结构的优化部分主要探讨了泛型如何帮助我们优化代码结构、减少重复代码,并提高代码的可维护性、可读性和复用性。以下是详细内容: 一、引言 Go 1.18 引入了泛型,极大地提高了语言的灵活性。泛型使得我们可以编写更加通用、可复用且类型安全的…

【1-快速上手】

文章目录前言简介什么是 Konva?安装 Konva概述它是如何工作的?基本形状样式事件拖放滤镜动画选择器序列化与反序列化性能前言 结合项目实际业务需求,在 Fabric、Konva 等图形化框架中,我选择了性能表现好的 Konva。首先去学习官方…

【LeetCode】209. 长度最小的子数组(前缀和 + 二分)

【LeetCode】209. 长度最小的子数组(前缀和 二分)题目描述前缀和二分优化前缀和总结二分总结题目描述 题目链接:【LeetCode】209. 长度最小的子数组(前缀和 二分) 给定一个含有 n 个整数的数组和一个整数 target。…

文件系统----底层架构

当我们谈到文件系统的时候,最重要的点在于:文件的内容与属性是如何存储在磁盘中的?以及操作系统是如何精准定位到这些文件内容的?在谈及文件的内核前,我们先来了解一下储存文件的硬件-----硬盘一.理解硬件首先我们来看…

小程序开发平台,自主开发小程序源码系统,多端适配,带完整的部署教程

温馨提示:文末有资源获取方式全开源与自主开发源码完全开放:开发者可自由修改前端界面、后端逻辑及数据库结构,支持深度定制(如调整用户端交互流程、商家端管理功能等)。技术栈透明:基于主流技术&#xff0…

stp拓扑变化分类

Max Age 20sHellotime 2sForward delay 153、拓扑改变需要多长时间1)根桥故障:需要50秒(Max age2个forwarding delay)2)非直连链路:非直连故障在稳定的STP网络,非根桥会定期收到来自根桥的BPDU报…

一、深度学习——神经网络

一、神经网络 1.神经网络定义:人工神经网络(Artificial Neural Network,ANN)也简称为神经网络(NN),是一种模仿生物神经网络结构和功能的计算模型。人脑可以看作是一个生物神经网络,由…

【牛客算法】 小红的奇偶抽取

文章目录 一、题目介绍1.1 题目描述1.2 输入描述1.3 输出描述1.4 示例二、解题思路2.1 核心算法设计2.2 性能优化关键2.3 算法流程图三、解法实现3.1 解法一:字符串分离法3.1.1 初级版本分析3.2 解法二:数学逐位构建法(推荐)3.2.1 优化版本分析四、总结与拓展4.1 关键优化技…

Maven 继承:构建高效项目结构的利器

一、引言 Maven 是一个强大的项目管理工具,它通过标准化的项目结构和依赖管理极大地简化了 Java 项目的开发流程。在 Maven 中,继承是一种非常有用的功能,它允许我们创建一个父项目,其他子项目可以继承这个父项目的配置信息&#…

Mysql组合索引的update在多种情况下的间隙锁的范围(简单来说)

简单来说,当 UPDATE 语句的 WHERE 条件使用了组合索引,并且需要锁定不存在的“间隙”来防止幻读时,就会产生间隙锁。间隙锁的范围取决于 WHERE 条件如何利用组合索引,以及数据库的隔离级别。 我们用图书馆的例子。比如&#xff1a…

什么是Apache Ignite的affinity(亲和性)

在 Apache Ignite 中, affinity(亲和性) 是一种用于控制数据分布和查询性能的重要机制。它允许开发者指定数据如何在集群中的节点之间分布,从而优化数据访问和查询效率。以下是关于 affinity 的详细解释:数据亲和性&a…

youtube图论

dfs排序lifo & fifo存储方式邻接矩阵dijstra处理过的保存/更新,意味着一个节点避免了重复访问bfs dfs

借助ssh实现web服务的安全验证

背景 公有云服务器 http 服务 80端口,想做到安全访问无须HTTPS 客户端证书方便、快捷、安全 SSH 隧道 本地代理 使用 SSH 隧道将 HTTP 服务“隐藏”在 SSH 之后: # 客户端建立隧道(将本地 8080 转发到服务器的 80 端口) ssh…

状态机在前端开发中的艺术:从理论到框架级实践

文章目录一 状态机:复杂逻辑的终结者1.1 什么是状态机?1.2 为何前端需要状态机?二 状态机核心概念深度解析2.1 有限状态机(FSM)与分层状态机(HSM)2.2 状态机的数学表示三 前端开发中的状态机实战…

把word中表格转成excle文件

把word中表格转成excle文件 from docx import Document from openpyxl import Workbook from pathlib import Path# 打开 Word 文档 document Document(./weather_report.docx) tables document.tables# 输出文件路径 output_file Path(./weather_report.xlsx)# 如果文件已存…

运维打铁: 阿里云 ECS 实例的高效运维与管理

文章目录思维导图正文内容一、实例基础管理1. 实例创建2. 实例配置调整3. 实例停止与启动二、性能监控与优化1. 系统性能指标监控2. 磁盘 I/O 优化3. 网络优化三、安全防护1. 防火墙设置2. 账号安全管理3. 数据备份与恢复四、自动化运维1. 脚本自动化2. 使用云助手五、成本优化…

RV1126平台(Buildroot Linux)+ SunplusIT SPCA2688 USB摄像头 RTSP推流全流程复盘与问题解决记录

# RK RV1126平台(Buildroot Linux) SunplusIT SPCA2688 USB摄像头 RTSP推流全流程复盘与问题解决记录一、平台与需求- **硬件平台**:Rockchip RV1126 - **操作系统**:基于Buildroot定制的Linux系统 - **USB摄像头**:Su…