Mysql-全局锁、表锁、行锁

本文已收录于专栏
《数据库》

目录

  • 全局锁
    • 概述说明
    • 开启方式
    • 应用场景
  • 表锁
    • 概念说明
    • 实现方式
      • 意向锁
    • 开启方式
  • 行锁
    • 概念说明
    • 实现方式
      • 记录锁:
      • 间隙锁
      • 临键锁
  • 总结提升

全局锁

概述说明

  全局锁是是对整个数据库实例加锁,加锁后整个实例就处于只读状态,后续的DML的写语句,DDL语句,已经更新操作的事务提交语句都将被阻塞。
其典型的使用场景是做全库的逻辑备份,对所有的表进行锁定,从而获取一致性视图,保证数据的完整性。
在这里插入图片描述

开启方式

加全局锁的方式:FLUSH TABLES WITH READ LOCK;   释放全局锁:UNLOCK TABLES

应用场景

  常用于执行一些需要对整个数据库进行操作的任务,比如备份、恢复和复制等。

表锁

概念说明

  表锁是指锁定整个表,当一个事务对表进行写操作时,其他事务无法对该表进行任何读写操作,直到该事务释放锁。表锁会限制并发访问,但可以减少锁的开销。

实现方式

意向锁

  意向锁:意向锁是⼀个表级锁,它解决的是表锁和⾏锁共存的问题。当我们需要给⼀个表加表锁的时候,我们需要根据去判断表中有没有数据⾏被锁定,以确定是否能加成
功。假如没有意向锁,那么我们就得遍历表中所有数据⾏来判断有没有⾏锁;有了意向锁这个表级锁之后,则我们直接判断⼀次就知道表中是否有数据⾏被锁定了。

  例如:要执⾏的事务 A 在申请⾏锁(写锁)之前,数据库会⾃动先给事务 A 申请表的意向排他锁。当事务 B 去申请表的互斥锁时就会失败,因为表上有意向排他锁之后事务 B 申请表的互斥锁时会被阻塞。

开启方式

      写锁:LOCK TABLES 表名 WRITE;    读锁:LOCK TABLES 表名 READ;

行锁

概念说明

  行锁是指锁定表中的某一行,当一个事务对某一行进行写操作时,其他事务无法对该行进行写操作,但可以进行读操作。行锁可以提高并发访问,但可能会增加锁的开销。

实现方式

记录锁:

  使用唯一索引进行等值查询的时候精确匹配到一条数据,此时就会对这条记录进行锁定
  例如:select * from t where id =6 for update;
在这里插入图片描述

间隙锁

  间隙锁指的是两个记录之间逻辑上没有填⼊数据的部分,是⼀个左开右开区域。
  例如:select * from t where id =3 for update; 或者 select * from t where id > 1 and id < 6 for update; 就会将(1,6)区间锁定。
在这里插入图片描述

临键锁

  临键锁是间隙加上它右边的记录组成的左开右闭区间。mysql 默认⾏锁类型就是 临 键 锁(Next-Key Locks) 。当使⽤唯⼀性索引,等值查询匹配到⼀条记录的时候,临键锁(Next-Key Locks)会退化成记录锁;没有匹配到任何记录的时候,退化成间隙锁。
  例如:select * from t where id > 1 and id <= 6 for update; 就会将(1,6]区间锁定
在这里插入图片描述

总结提升

  在实际应用中,需要根据实际需求选择合适的锁定方式,以提高数据库的性能和并发能力,并确保数据的一致性。

在这里插入图片描述


🎯 此文章对你有用的话记得留言+点赞+收藏哦🎯

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

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

相关文章

立体视觉几何 (二)

1.视差 2.立体匹配 立体匹配的基本概念: 匹配目标: 在立体匹配中&#xff0c;主要目标是确定左图像中像素的右图像中的对应像素。这个对应像素通常位于相同的行。视差&#xff08;Disparity&#xff09;: 视差 d 是右图像中对应像素 xr 和左图像中像素 xl 之间的水平位置差。视…

对MODNet 主干网络 MobileNetV2的剪枝探索

目录 1 引言 1.1 MODNet 原理 1.2 MODNet 模型分析 2 MobileNetV2 剪枝 2.1 剪枝过程 2.2 剪枝结果 2.2.1 网络结构 2.2.2 推理时延 2.3 实验结论 3 模型嵌入 3.1 模型保存与加载 法一&#xff1a;保存整个模型 法二&#xff1a;仅保存模型的参数 小试牛刀 小结…

MSPM0L1306例程学习-UART部分(2)

MSPM0L1306例程学习系列 1.背景介绍 写在前边的话&#xff1a; 这个系列比较简单&#xff0c;主要是围绕TI官网给出的SDK例程进行讲解和注释。并没有针对模块的具体使用方法进行描述。所有的例程均来自MSPM0 SDK的安装包&#xff0c;具体可到官网下载并安装: https://www.ti…

YOLOv8改进 | 主干篇 | 低照度图像增强网络SCINet改进黑暗目标检测(全网独家首发)

一、本文介绍 本文给大家带来的改进机制是低照度图像增强网络SCINet,SCINet(自校正照明网络)是一种专为低光照图像增强设计的框架。它通过级联照明学习过程和权重共享机制来处理图像,优化了照明部分以提升图像质量。我将该网络集成在YOLOv8的主干上针对于图像的输入进行增…

【QT+QGIS跨平台编译】之三:【OpenSSL+Qt跨平台编译】(一套代码、一套框架,跨平台编译)

文章目录 一、OpenSSL介绍二、OpenSSL配置三、Window环境下配置四、Linux环境下配置五、Mac环境下配置 一、OpenSSL介绍 OpenSSL是一个开放源代码的软件库包&#xff0c;应用程序可以使用这个包来进行安全通信&#xff0c;避免窃听&#xff0c;同时确认另一端连接者的身份。这…

vectorCast手动添加测试用例配置输入参数和期望值

1.选中函数&#xff0c;点击右键选择插入测试用例。这里所选择的插入测试用例区别于之前的测试用例的地方在于&#xff0c;这里插入测试用例是手动配置的&#xff0c;之前的是自动生成的。手动配置可以自定义选择输入参数和期望值。 2.添加测试用例后&#xff0c;点击测试用例&…

代码随想录算法训练营第二十九天|51. N皇后

51. N皇后 public List<List<String>> solveNQueens(int n) {List<List<String>> res new ArrayList<>();return null;}void backtracking1(int n, int row, int[] columns) {// 是否在所有n行里都摆放好了皇后?if (row n) {count;// 找到了新…

Mybatis 动态SQL删除操作

实现动态删除多个数据,这里我们需要用到 foreach 标签,这个标签还可以运用到批量插入,反正需要对集合进行遍历时就可以使用该标签,标签有如下属性 : 新建了一个 userInfo2Mapper 接口,然后写下如下代码,声明 batchDelete 方法 package com.example.mybatisdemo.mapper; import…

C++ 赋值运算符重载

就像其他运算符一样&#xff0c;您可以重载赋值运算符&#xff08; &#xff09;&#xff0c;用于创建一个对象&#xff0c;比如拷贝构造函数。 下面的实例演示了如何重载赋值运算符。 #include <iostream> using namespace std;class Distance {private:int feet; …

城市道路智慧养护顶层设计建议书

项目通过对国家在推动智慧交通领域的健康发展上发布的如&#xff1a;《交通强国建设纲要》、《推进综合交通运输大数据发展行动纲要(2020-2025年)》、《数字交通发展规划纲要》等相关政策的深入理解与研究&#xff0c;结合“互联网”、“智能化”、“智慧化”等理念,对国家提出…

解决elementUI中使用checkbox无法选中的问题

解决elementUI中使用checkbox无法选中的问题 事情的开始是这样的&#xff0c;有一个属性是isCheck&#xff0c;后端是没有返回这个字段的&#xff0c;但是前端需要将这个属性绑定到el-checkbox上去&#xff0c;但是前端采用循环的方式去生成el-checkbox不行。isCheck每个都有&a…

【算法】利用模拟算法、规律解算法题(C++)

文章目录 1. 前言2. 算法题1576.替换所有的问号495.提莫攻击6.Z字形变换38.外观数列1419.数青蛙 1. 前言 模拟算法 即模拟问题过程来解决问题的算法。 对于一些算法题&#xff0c;我们只需要将题目的过程 用代码编写出来&#xff0c;再结合其他方法&#xff0c;就可以解决。 …

Geogebra绘制分段函数、导数

分段函数绘制 一、下载Geogebra6&#xff0c;输入下面的代码: f(x)x g(x)sin(x) h(x)x^3 p(x)如果(x<0, f(x), x<2, h(x), g(x)) 二、我们会得到下面的图 三、把左边的三个圆圈点击取消掉&#xff0c;右侧就变成了分段函数 导数绘制 f(x)x^3-4x^2x-6 f 效果如下&…

JavaSE复习流程

一.初识JAVA 1.JAVA语言之父--高斯林。 2.javac--字节码文件 3.注释&#xff1a;单行注释&#xff0c;多行注释&#xff0c;文档注释。 二.数据类型与变量 1.数据类型 类型 byte shortintlongfloatdoublecharboolean大小1字节2字节4字节8字节4字节8字节1字节包装类型Byt…

GitLab升级多个版本-企业实战

文章目录 GitLab升级记录升级说明升级路径升级规划拉取镜像备份数据git_backup.sh备份数据升级版本13.9.4 > 13.12.15排错13.12.15 > 14.0.12排错14.0.12 > 14.3.614.3.6 &g

SCTP, TCP, UDP, IP, ICMP都在哪一层?(TCP/IP网络通信协议学习)

TCP/IP网络通信协议最早是由罗伯特卡恩&#xff08;Robert E. Kahn&#xff09;和文顿瑟夫&#xff08;Vinton G. Cerf&#xff09;于1972年提出的&#xff0c;它是一个实际的协议栈。 OSI七层网络通信协议最早是由国际标准化组织&#xff08;ISO&#xff09;于1977年提出的&am…

使用AFPN渐近特征金字塔网络优化YOLOv8改进小目标检测效果(不适合新手)

目录 简单概述 算法概述 优化效果 参考文献 文献地址&#xff1a;paper 废话少说&#xff0c;上demo源码链接&#xff1a; 简单概述 AFPN的核心思想&#xff1a;AFPN主要通过引入渐近的特征融合策略&#xff0c;逐步整合底层、高层和顶层的特征到目标检测过程中。这种融合…

决斗 题解

决斗 题解 赛题来自 OIFHA 第四场模拟赛。 原题展现 青蛙哥与名侦探柯南正在进行一场对决。 他们两个人每人有 n n n 张牌&#xff0c;每张牌有一个点数。 并且在接下来的 n n n 个回合中每回合青蛙哥与名侦探柯南两人会各自打出一张牌。 每回合裁判会检查&#xff0c;…

文件上传笔记整理

文件上传 web渗透的核心&#xff0c;内网渗透的基础 通过上传webshell文件到对方的服务器来获得对方服务器的控制权 成功条件 文件成功上传到对方的服务器&#xff08;躲过杀软&#xff09; 知道文件上传的具体路径 上传的文件可以执行成功 文件上传的流程 前端JS对上传文件进行…

Sqoop与Kafka的集成:实时数据导入

将Sqoop与Kafka集成是实现实时数据导入和流处理的关键步骤之一。Sqoop用于将数据从关系型数据库导入到Hadoop生态系统中&#xff0c;而Kafka则用于数据流的传输和处理。本文将深入探讨如何使用Sqoop与Kafka集成&#xff0c;提供详细的步骤、示例代码和最佳实践&#xff0c;以确…