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

【Mysql】-锁,行级锁

Mysql

mysql中的行锁

在 MySQL 的 InnoDB 存储引擎中,行级锁通常是加在索引上的,而不是直接加在数据行上。这种机制是基于索引的锁定策略,具体来说:

  1. 主键索引:如果查询更新使用了主键进行查找,InnoDB 会直接在主键索引上加锁。

  2. 唯一索引:如果查询更新使用了唯一索引(UNIQUE INDEX)进行查找,并且能够通过该唯一索引确定唯一的记录,那么 InnoDB 会在唯一索引上加锁。

  3. 非唯一索引:如果查询更新使用了非唯一索引进行查找,InnoDB 会在非唯一索引上加锁。但是,由于非唯一索引可能对应多条记录,InnoDB 还需要在这些记录的聚簇索引(通常是主键索引)上加锁以确保数据的一致性。

  4. 无索引:如果查询更新没有使用任何索引(例如全表扫描),InnoDB 会在聚簇索引(通常是主键索引)的所有记录上加锁。

具体示例

假设有一个表 users,其结构如下:

Sql

CREATE TABLE users (id INT PRIMARY KEY,username VARCHAR(255) UNIQUE,email VARCHAR(255)
);
  • 如果执行以下查询:

    Sql
    SELECT * FROM users WHERE id = 1 FOR UPDATE;

    InnoDB 会在 id 索引(即主键索引)上加锁。

  • 如果执行以下查询:

    Sql
    SELECT * FROM users WHERE username = 'john_doe' FOR UPDATE;

    InnoDB 会在 username 索引(即唯一索引)上加锁。

  • 如果执行以下查询:

    Sql
    SELECT * FROM users WHERE email = 'john@example.com' FOR UPDATE;

    假设 email 没有索引,InnoDB 将执行全表扫描并在所有记录的主键索引上加锁。

总结

行级锁通常不是直接加在数据行上的,而是加在与数据行相关的索引项上。这是因为索引提供了快速定位数据的方式,同时也可以高效地管理锁。通过这种方式,InnoDB 可以最小化锁的影响范围,提高并发性能。如果你希望避免不必要的锁,确保你的查询尽可能使用合适的索引是非常重要的。

*** Mysql IX IS锁是表级锁,如果表中有数据行索引加了索引行锁x s 锁 就会在表上加上iX 或 IS 表明 表内部的数据正被加锁了

Oracle

在 Oracle 数据库中,行级锁是直接加在数据行上的,而不是索引上。Oracle 使用一种称为“多版本并发控制”(Multiversion Concurrency Control, MVCC)的技术来管理事务和锁,这与 MySQL 的 InnoDB 存储引擎有一些相似之处,但实现细节有所不同。

Oracle 中的行级锁

  • 锁定机制:当一个事务修改某一行时,Oracle 会在该行上放置一个排他锁(Exclusive Lock)。这个锁确保了在同一时间只有一个事务可以修改这一行。

  • 索引的作用:虽然锁是直接放在数据行上的,但索引对于快速定位需要锁定的行非常重要。通过索引,Oracle 可以迅速找到并锁定相关的数据行,而不需要进行全表扫描。

  • 锁定粒度:Oracle 的行级锁只锁定被修改的行,这样可以最大限度地减少对其他事务的影响,并提高并发性能。

锁模式

Oracle 提供了几种不同的锁模式,包括:

  • 共享锁 (S Lock):允许多个事务读取同一行,但阻止任何事务对其进行修改。
  • 排他锁 (X Lock):允许一个事务独占访问某一行,阻止其他事务对该行进行读取或修改。
  • 行级共享锁 (Row Share Lock, RS Lock):允许其他事务获取行级共享锁或读取该行,但阻止其他事务获取排他锁。
  • 行级排他锁 (Row Exclusive Lock, RX Lock):允许其他事务读取该行,但阻止其他事务获取任何类型的写锁。

示例

假设有一个表 employees,其结构如下:

Sql

CREATE TABLE employees (id NUMBER PRIMARY KEY,name VARCHAR2(100),salary NUMBER
);
  • 如果执行以下更新语句:

    Sql
    UPDATE employees SET salary = 50000 WHERE id = 1;

    Oracle 会在 id = 1 的那条记录上放置一个排他锁。

  • 如果执行以下查询语句(使用 FOR UPDATE 子句):

    Sql

    SELECT * FROM employees WHERE id = 1 FOR UPDATE;

    Oracle 也会在 id = 1 的那条记录上放置一个排他锁,防止其他事务修改这条记录。

总结

在 Oracle 中,行级锁是直接加在数据行上的,而不是索引上。索引用于快速定位需要锁定的行,但实际的锁是加在数据行上的。这种设计使得 Oracle 能够高效地管理并发访问,同时保证数据的一致性和隔离性。

相关文章:

【Mysql】-锁,行级锁

Mysql mysql中的行锁 在 MySQL 的 InnoDB 存储引擎中,行级锁通常是加在索引上的,而不是直接加在数据行上。这种机制是基于索引的锁定策略,具体来说: 主键索引:如果查询更新使用了主键进行查找,InnoDB 会直…...

手机功耗技术领域

手机功耗技术领域 器件 器件-电池 提升电池能量密度 提升正极电压、升级负极材料正极电压方面,目前行业还是以4.5V体系为主;4.53V体系预计24-25年落地;负极材料方面,石墨体系每年2%能量密度提升迭代; 掺硅方案目前…...

Golang | Leetcode Golang题解之第493题翻转对

题目&#xff1a; 题解&#xff1a; type fenwick struct {tree []int }func newFenwickTree(n int) fenwick {return fenwick{make([]int, n1)} }func (f fenwick) add(i int) {for ; i < len(f.tree); i i & -i {f.tree[i]} }func (f fenwick) sum(i int) (res int)…...

linux笔记(yum本地源仓库搭建)

一、准备工作 安装必要的软件包 在大多数 Linux 发行版中&#xff0c;Yum 已经默认安装。如果系统中没有安装&#xff0c;可以根据发行版的包管理器进行安装。 准备本地源文件 可以是光盘镜像&#xff08;如果是从光盘安装系统&#xff09;&#xff0c;或者是已经下载好的系…...

K8S系列-Kubernetes网络

一、Kubernetes网络模型 ​ Kubernetes网络模型设计的一个基础原则是&#xff1a;每个Pod都拥有一个独立的IP地址&#xff0c;并假定所有Pod都在一个可以直接连通的、扁平的网络空间中&#xff0c;不管它们是否运行在同一个Node&#xff08;宿主机&#xff09;中&#xff0c;都…...

Excel 对数据进行脱敏

身份证号脱敏&#xff1a;LEFT(A2,6)&REPT("*",6)&RIGHT(A2,6) 手机号脱敏&#xff1a;LEFT(B2,3)&REPT("*",5)&RIGHT(B2,3) 姓名脱敏&#xff1a;LEFT(C2,1)&REPT("*",1)&RIGHT(C2,1) 参考&#xff1a; excel匹配替换…...

OJ-1014田忌赛马

示例1&#xff1a; 输入 11 8 20 10 13 7 输出 1 示例2&#xff1a; 输入 11 12 20 10 13 7 输出 2 示例3&#xff1a; 输入 1 2 3 4 5 6 输出 6 解题思路&#xff1a; 问题的关键在于调整数组a的顺序,使得尽可能多的a[i] > b[i]。为了达到最优结果,我们可以采用贪心的策…...

Excel重新踩坑3:条件格式;基本公式运算符;公式中的单元格引用方式;公式菜单栏其他有用的功能说明;

0、前言&#xff1a;以下内容是学习excel公式的基础内容。 1、需求&#xff1a;将表格特定区域中数值大小大于等于30&#xff0c;小于等于80的单元格&#xff0c;颜色填充为红色&#xff0c;大于80的&#xff0c;颜色填充为黄色。 新建规则之后也可以通过该功能清除规则。 2、基…...

【AI知识点】FAISS如何提高检索效率?

【AI论文解读】【AI知识点】【AI小项目】【AI战略思考】 FAISS&#xff08;Facebook AI Similarity Search&#xff09; 是一个高效的相似度搜索库&#xff0c;专门设计用于处理大规模的向量检索任务&#xff0c;尤其是在稠密向量的检索中表现出色。FAISS 能够显著提高检索效率…...

【Git】Gitlab进行merge request的时候,出现待合并分支合并了主分支的问题的解决

最近在公司开始用merge request进行代码合并了。 然后不知道为啥&#xff0c;如果待合并分支&#xff08;A&#xff09;进行merge request到主分支&#xff08;B&#xff09;的时候&#xff0c;如果A和B有冲突&#xff0c;然后我在gitlab上使用页面进行冲突的解决&#xff0c;比…...

jetson nano ubuntu20.04安装ros-Noetic

jetson nano ubuntu20.04 安装ros-Noetic 一. 初始准备nano连接wifinano网络配置二. 查看系统版本三. 开始安装1. 移除不需要的 amd64 架构2. 配置软件源3.安装 ROS Melodic`4. 解决 rosdep update报错`一. 初始准备 nano连接wifi nano网络配置 二. 查看系统版本 lsb_relea…...

【数据结构与算法】走进数据结构的“时间胶囊”——栈

大家好&#xff0c;我是小卡皮巴拉 文章目录 目录 引言 一.栈的基本概念 1.1 定义 1.2 特性 1.3 基本操作 二.栈的实现方式 2.1 顺序栈 2.2 链栈 三.顺序栈的实现 定义顺序栈的结构 初始化 入栈 检查栈是否为空 出栈 销毁 四.链栈的实现 定义链栈的结构 初始…...

伺服增量式和绝对式的本质区别?

伺服增量式和绝对式的本质区别&#xff1f; 增量式编码器是将位移转换成周期性的电信号&#xff0c;再把这个电信号转变成计数脉冲&#xff0c;用脉冲的个数表示位移的大小。以转动时输出脉冲&#xff0c;通过计数设备来知道其位置&#xff0c;当编码器不动或停电时&#xff0c…...

应对 .DevicData-X-XXXXXXXX 勒索病毒:防御与恢复策略

引言 随着信息技术的快速发展&#xff0c;网络安全问题愈发严峻。勒索病毒作为一种恶性网络攻击手段&#xff0c;已成为企业和个人面临的重大威胁之一。尤其是 .DevicData-X-XXXXXXXX 勒索病毒&#xff0c;其通过加密用户数据并勒索赎金&#xff0c;给受害者带来了巨大的经济损…...

【代码随想录——数组——二刷】

数组 1. 二分查找(704) 给定一个 n 个元素有序的&#xff08;升序&#xff09;整型数组 nums 和一个目标值 target &#xff0c;写一个函数搜索 nums 中的 target&#xff0c;如果目标值存在返回下标&#xff0c;否则返回 -1。 1.1 二分法的第一种写法 我们定义 target 是在…...

spring-boot(4)

1.VueRouter安装与使用 2.状态管理VueX 3. 4. 5. 6....

深度学习模型:原理、架构与应用

深度学习(Deep Learning)是机器学习中的一个分支,基于人工神经网络的发展,尤其是多层神经网络的研究,使其在语音识别、图像处理、自然语言处理等领域取得了显著进展。深度学习的核心是通过大量数据的训练,学习到数据的内在结构和模式,并且具备自动从复杂的输入中提取特征…...

玩客云Armbian安装Casaos

#armbian安装docker apt install docker.io #armbian判断docker是否正常运行 systemctl status docker #查看版本 docker version #安装casaos方式一 wget -qO- https://get.casaos.io | bash #安装casaos方式二 curl -fsSL https://get.casaos.io | bash...

redis过期提醒

文章目录 redis过期提醒 redis过期提醒 有一次看redis的配置文件发现一个notify-keyspace-events配置&#xff0c;注释里边长篇大论的&#xff0c;那我得看看这是干啥的&#xff0c;看完注释内容&#xff0c;发现不得了了&#xff0c;redis竟然还有过期提醒的功能 接下来得大…...

AnaTraf | 提升网络性能:深入解析网络关键指标监控、TCP重传与TCP握手时间

AnaTraf 网络性能监控系统NPM | 全流量回溯分析 | 网络故障排除工具 在当今的数字化时代&#xff0c;网络的稳定性和性能对企业的运营效率至关重要。无论是内部通信、应用程序的运行&#xff0c;还是对外提供服务&#xff0c;网络都发挥着关键作用。对于网络工程师或IT运维人员…...

手把手教你用FUTURE POLICE:会议录音秒变带时间轴字幕

手把手教你用FUTURE POLICE&#xff1a;会议录音秒变带时间轴字幕 1. 为什么需要高精度字幕对齐&#xff1f; 在日常工作中&#xff0c;我们经常遇到这样的场景&#xff1a;重要会议录音需要整理成文字稿&#xff0c;但人工听写耗时耗力&#xff1b;视频剪辑时需要添加字幕&a…...

别再踩坑了!Jetson Nano/Xavier NX上PyTorch和torchvision版本匹配保姆级指南(含JetPack 5/6)

Jetson设备PyTorch环境配置终极避坑手册&#xff1a;从版本匹配到性能调优 刚拿到Jetson Nano或Xavier NX的开发者们&#xff0c;十个里有九个会在PyTorch环境配置上栽跟头。不是torchvision报错就是CUDA不可用&#xff0c;最崩溃的是好不容易装好了却发现性能还不如树莓派。本…...

别再手动改配置了!用Docker Compose一键部署Pikachu靶场,5分钟搞定测试环境

5分钟极速搭建Pikachu靶场&#xff1a;Docker Compose自动化实战指南 每次准备网络安全练习环境时&#xff0c;最头疼的莫过于反复安装配置各种服务——PHP版本不兼容、MySQL连接失败、Web服务器配置错误...这些琐碎问题消耗了本应用于渗透测试学习的宝贵时间。今天要分享的这套…...

用战神引擎开服后,别忘了这几步:服务器安全、日志监控与性能调优指南

战神引擎开服后的高阶运维指南&#xff1a;安全加固、日志监控与性能调优实战 当你成功用战神引擎架设传奇手游服务器后&#xff0c;真正的挑战才刚刚开始。服务器能跑起来只是第一步&#xff0c;如何让它跑得稳、跑得安全、跑得高效&#xff0c;才是区分普通服主和专业运维的关…...

Emacs verilog-mode实战:5分钟搞定AUTOARG自动参数生成(附避坑指南)

Emacs verilog-mode实战&#xff1a;5分钟掌握AUTOARG高效参数生成技巧 在数字电路设计领域&#xff0c;Verilog作为主流硬件描述语言&#xff0c;其模块化开发方式虽然提高了代码复用性&#xff0c;却也带来了大量重复性工作。模块接口定义中的参数列表维护就是典型痛点——每…...

教无人机操控3年,这款仿真软件让我彻底告别“真机实训焦虑”

作为无人机专业实操教师&#xff0c;深耕一线教学3年&#xff0c;最大的痛点莫过于“真机实训难”——相信同行们都有共鸣&#xff0c;无人机操控教学看似是“练手”&#xff0c;实则处处是坑&#xff0c;每一个难题都让人头疼不已&#xff0c;甚至一度让我陷入教学焦虑。整理了…...

Graphormer在药物发现中的应用:催化剂吸附预测落地实践

Graphormer在药物发现中的应用&#xff1a;催化剂吸附预测落地实践 1. 项目背景与价值 在药物研发和材料科学领域&#xff0c;分子属性预测一直是一项耗时且昂贵的任务。传统实验方法需要大量试错&#xff0c;而计算化学方法又面临精度与效率的平衡问题。Graphormer作为一款基…...

太原烘焙培训排名

在太原选择烘焙培训机构时&#xff0c;许多朋友会关注不同机构的教学质量与特色。以下整理了一些选择时可以考虑的方面&#xff0c;供您参考。教学方式与内容部分机构采用以实操为主的教学模式&#xff0c;例如山西旭梦圆食品有限公司的课程安排中&#xff0c;实践操作占较大比…...

手把手教你用Flotherm做热管仿真

&#x1f393;作者简介&#xff1a;科技自媒体优质创作者 &#x1f310;个人主页&#xff1a;莱歌数字-CSDN博客 &#x1f48c;公众号&#xff1a;莱歌数字&#xff08;B站同名&#xff09; &#x1f4f1;个人微信&#xff1a;yanshanYH 211、985硕士&#xff0c;从业16年 从…...

Magisk完整实践指南:从Root权限获取到系统级定制

Magisk完整实践指南&#xff1a;从Root权限获取到系统级定制 【免费下载链接】Magisk The Magic Mask for Android 项目地址: https://gitcode.com/GitHub_Trending/ma/Magisk Magisk作为Android系统Root权限管理的主流解决方案&#xff0c;提供了系统级定制能力而无需修…...