MySQL中有几种类型的锁?

锁粒度来分,有表锁、页锁和行锁。

加锁机制划分,有乐观锁和悲观锁。

兼容性划分,有共享锁和排他锁。

锁模式划分,有记录锁,间隙锁,next-key锁,意向锁、插入意向锁

全局锁了解吗? 

全局锁是对整个数据库实例加读锁,整个数据库处于只读状态,所有写操作被阻塞,直到全局锁被释放。

使用场景是全库备份,或者数据迁移时,使用全局锁来保证数据的一致性。

-- 锁定整个数据库
FLUSH TABLES WITH READ LOCK;-- 执行备份操作
-- 例如使用 mysqldump 进行备份
! mysqldump -u username -p database_name > backup.sql-- 释放全局锁定
UNLOCK TABLES;

表锁了解吗?

常见于MyISAM引擎,InnoDB可以通过LOCK TABLES加锁

适合读多写少,全表扫描和表结构变更时使用。

表锁也分为共享锁(读锁),排他锁(写锁)

MyISAM在指向SELECT操作时会自动加读锁,UPDATE/DELETE/INSERT的时候会自动加写锁

对于 InnoDB 引擎,无索引的 UPDATE/DELETE 只能先进行全表扫描,可能会导致锁大量行被锁定,类似于表锁。

ALTER TABLE会加排它锁

说说MySQL的行锁? 

InnoDB中最细粒度的锁,锁定表中的一行记录,允许其他事务访问表中的其他行。

有索引的情况下,通过索引只锁满足条件的行无索引的情况下,全表遍历,遍历一行就加一行行锁,最差的情况会锁定所有行,直到事务完成才会释放所有行锁。

行锁又可以细分为记录锁,间隙锁和临键锁

通过SELECT .... FOR UPDATE可以加排它锁。

通过SELECT .... IN SHARE MODE可以加共享锁。 

select for update有什么需要注意的?

  • 必须在事务中使用,否则锁会立即释放。
  • 使用时注意是否命中索引,否则可能会锁大量行。

说说记录锁

记录锁是行锁的最基本的表现形式,当我们使用唯一索引或者主键索引进行等值查询并显式指定FOR UPDATE的时候,MySQL会为该行添加排它锁类型的记录锁,禁止其他行读取或修改记录。

 注意使用非主键索引进行UPDATE时的锁定路径:辅助索引 → 主键索引

间隙锁了解吗?

范围查询或者不存在的记录查询时,用于锁定记录之间的间隙,防止其他事务在范围中插入新纪录,在可重复读的事务隔离级别下生效,主要为了防止幻读现象。

临键锁了解吗?

临键锁就是间隙锁+记录锁,锁住记录以及记录之前的间隙,左开右闭,范围查询时生效。

当使用唯一索引的等值查询匹配到一条记录时,临键锁会退化成记录锁;如果没有匹配到任何记录,会退化成间隙锁

意向锁是什么?

意向锁是一种表级锁,表示事务打算对表中的某些行数据加锁,但是不会先直接锁定行数据本身。

由InnoDB自动管理,当事务需要添加行锁时,会先在表上添加意向锁。这样当另一个事务要添加表锁的时候,可以通过查看表上的意向锁,快速判断表级锁与现有行锁的冲突,避免逐行扫描。

当执行SELECT .... LOCK IN SHARE MODE的时候,会自动添加意向共享锁;当执行 SELECT .... FOR UPDATE的时候,会自动添加意向排他锁。

意向锁之间相互兼容,也不会和行锁冲突。

当前锁ISIXS(表级)X(表级)
IS
IX
S(表级)
X(表级)

MySQL的乐观锁和悲观锁了解吗? 

悲观锁是一种"先上锁再操作"的保守策略,它假设数据被外界访问时必然会产生冲突,因此在数据处理过程中全程加锁,保证同一时间只有一个线程可以访问数据。MySQL 中的行锁和表锁都是悲观锁。

乐观锁会假设并发操作不会总发生冲突,属于小概率事件,因此不会在读取数据时加锁,而是在提交更新时才检查数据是否被其他事务修改过。常见的实现方式有版本号机制和时间戳机制。通过在表中增加 version 字段或者 timestamp 字段来实现。

如何通过乐观锁和悲观锁解决库存超卖的问题?

悲观锁通过 SELECT ... FOR UPDATE 在查询时直接锁定记录,确保其他事务必须等待当前事务完成才能操作该行数据。

乐观锁通过在表中增加 version 字段作为判断条件。

有遇到过MySQL的死锁问题吗?是如何解决的?

MySQL的死锁问题是多个事务同时持有资源并且相互等待对方的资源释放引起的。访问相同的资源,但顺序不同,就会导致死锁。我用SHOW ENGINE INNODB STATUS查看死锁信息,发现是加锁顺序不一致导致的死锁问题,调整加锁顺序之后恢复正常。

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

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

相关文章

/var/lib/docker/overlay2目录过大怎么办

/var/lib/docker/overlay2 是 Docker 默认用于存储 容器镜像和容器运行时数据 的核心目录,基于 overlay2 存储驱动实现。以下是其具体作用和内容的详细解析: 1. overlay2 目录的作用 存储镜像分层结构: Docker 镜像采用分层设计,o…

JimuReport:一款免费的数据可视化报表工具

JimuReport(积木报表)是一款免费的企业级数据可视化报表软件,提供拖拽的方式像搭建积木一样完成在线设计,功能涵盖数据报表、打印设计、图表报表、门户设计、大屏设计等。 数据源 JimuReport 支持 30 多种数据源,包括…

Neo4j.5.X社区版创建数据库和切换数据库

在使用Neo4j数据库(版本:neo4j-community-5.22.0)时,系统自带的“neo4j”和“system”数据库适用于日常的简单学习和练习,但对于新的项目,将项目数据与练习数据混用会带来诸多不便,例如查询效率…

DAY33神经网络

浙大疏锦行 定义了一个简单的神经网络,主要是掌握pytorch框架

拼团系统多层限流架构详解

拼团系统多层限流架构详解 一、整体架构设计理念 多层限流采用"层层设防"思想,通过网关层全局流量控制→服务层接口粒度限流→本地资源隔离→热点参数精准防护的四级防御体系,实现从粗到细的流量治理,确保大促期间系统稳定性。 …

[ctfshow web入门] web92 `==`特性与intval特性

信息收集 和之前的题差不多,这次是使用了不严格相等的,详情看这篇博客: 和 在 PHP 中有何区别?一共包含哪些部分? 首先,不能使$num 4476,然后需要使intval($num,0)4476 include("flag…

在Springboot项目部署时遇到,centos服务器上,curl请求目标地址不通 ,curl -x 可以请求通的解决办法

在甲方服务器部署项目时,通常遇到需要开通外网权限的问题,有的是直接给开通服务器的白名单,就可以直接访问白名单外网地址了。也有的是通过网络转发,将url前面的部分替换,可以进行网络请求。有一次遇到一个罕见的&…

Python异步爬虫编程技巧:从入门到高级实战指南

Python异步爬虫编程技巧:从入门到高级实战指南 🚀 📚 目录 前言:为什么要学异步爬虫异步编程基础概念异步爬虫核心技术栈入门实战:第一个异步爬虫进阶技巧:并发控制与资源管理高级实战:分布式…

JMeter-SSE响应数据自动化3.0

背景 此次因为多了一些需要过滤排除的错误(数量很少),还需要修改下JMeter的jtl文件输出数据(后续统计数据需要) 所以只涉及到JSR脚本的一些改动(此部分改动并不会影响到JMeter的HTML报告) 改动 主要通过设置JMeter中prev输出数据变量threadN…

012 进程状态和优先级

🦄 个人主页: 小米里的大麦-CSDN博客 🎏 所属专栏: Linux_小米里的大麦的博客-CSDN博客 🎁 GitHub主页: 小米里的大麦的 GitHub ⚙️ 操作环境: Visual Studio 2022 文章目录 进程状态和优先级一、进程状态分类特殊状态说明 二、如何查看进程…

React JSX原理

JSX本质 实质上是React.createElement()的语法糖

Java-51 深入浅出 Tomcat 手写 Tomcat 类加载机制 双亲委派机制 生命周期 插件化

点一下关注吧!!!非常感谢!!持续更新!!! 🚀 AI篇持续更新中!(长期更新) 目前2025年06月13日更新到: AI炼丹日志-28 - Aud…

从C++编程入手设计模式——责任链模式

从C编程入手设计模式——责任链模式 ​ 当我们的一个请求需要多个对象去处理,但具体由谁来处理,是根据情况动态决定的。例如,一个日志系统中,可能希望把错误信息写入文件,把提示信息输出到控制台,而不是每…

泛型方法调用需要显示指定泛型类型的场景

泛型类型的推断确定 一般来说&#xff0c;泛型类型的推断可以由以下几个场景确定&#xff1a; 变量定义指定类型 List<String> strList new ArrayList<>();ArrayList的泛型类型是依据变量的类型确定的。 方法返回值确定 Overridepublic Function<List<I…

Deep Research:开启深度研究的智能新时代

在当今信息爆炸的时代&#xff0c;人们面临着海量的信息&#xff0c;无论是专业人士还是普通消费者&#xff0c;都迫切需要一种高效、精准的方式来获取和分析信息。OpenAI 推出的 Deep Research&#xff0c;宛如一颗璀璨的新星&#xff0c;在知识的海洋中为我们导航&#xff0c…

曼昆《经济学原理》第九版 宏观经济学 第二十四章失业与自然失业率

以下是曼昆《经济学原理》第九版宏观经济学第二十四章**“失业与自然失业率”**的详细讲解&#xff0c;从零基础开始构建知识框架&#xff0c;结合中国实际案例与生活化比喻&#xff0c;帮助小白系统理解核心概念&#xff1a; 一、知识框架&#xff1a;失业的“全景图” 1. 核…

【软考高级系统架构论文】论软件系统架构风格

论文真题 请以“软件系统架构风格”为论题,依次从以下三个方面进行论述: 1、概要叙述你参与分析和开发的软件系统开发项目以及你所担任的主要工作。 2、分析软件系统开发中常用的软件系统架构风格有哪些?详细阐述每种风格的具体含义。 3、详细说明在你所参与的软件系统开发项…

LeetCode--35.搜索插入位置

解题思路&#xff1a; 1.获取信息&#xff1a; 给定一个升序排列的数组和一个整数&#xff0c;要求查找该整数应该在数组中插入的位置 限制条件是&#xff0c;要求时间复杂度为O(log N) 2.分析题目&#xff1a; 时间复杂度要求O(log N)&#xff0c;那么就使用二分查找法&#x…

Unix、Linux、POSIX、Minix 区别与联系

一、Unix&#xff1a;现代操作系统的技术原型 诞生&#xff1a;1969年贝尔实验室&#xff0c;用C语言重写后实现跨平台&#xff08;1973年&#xff09;。核心设计&#xff1a; 一切皆文件&#xff08;设备/进程均抽象为文件&#xff09;。管道&#xff08;|&#xff09;和文本…

python计算长方形的周长 2025年3月青少年电子学会等级考试 中小学生python编程等级考试一级真题答案解析

python计算长方形的周长 2025年3月 python编程等级考试一级编程题 博主推荐 所有考级比赛学习相关资料合集【推荐收藏】 1、Python比赛 信息素养大赛Python编程挑战赛 蓝桥杯python选拔赛真题详解 蓝桥杯python省赛真题详解 蓝桥杯python国赛真题详解 2、Python考级 p…