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

【MySQL】一文带你理清<表级锁>(表锁,元数据锁,意向锁)

前言

大家好吖,欢迎来到 YY 滴MySQL系列 ,热烈欢迎! 本章主要内容面向接触过C++ Linux的老铁
主要内容含:
在这里插入图片描述

欢迎订阅 YY滴C++专栏!更多干货持续更新!以下是传送门!

  • YY的《C++》专栏
  • YY的《C++11》专栏
  • YY的《Linux》专栏
  • YY的《数据结构》专栏
  • YY的《C语言基础》专栏
  • YY的《初学者易错点》专栏
  • YY的《小小知识点》专栏
  • YY的《单片机期末速过》专栏
  • YY的《C++期末速过》专栏
  • YY的《单片机》专栏
  • YY的《STM32》专栏
  • YY的《数据库》专栏
  • YY的《数据库原理》专栏

目录

  • 一.表级锁
    • 表级锁的基本概念&分类【表锁,元数据锁,意向锁】
    • 【1】表锁
    • 【2】元数据锁:MDL
    • 【3】意向锁
      • 1.意向锁的由来
      • 2.意向锁的相关语法(意向共享锁&意向排他锁)(包含语法和演示)

一.表级锁

表级锁的基本概念&分类【表锁,元数据锁,意向锁】

  • 表级锁,每次操作锁住整张表。锁定粒度大, 发生锁冲突的概率最高 ,并发度最低。应用在MISAM、InnoDB、BDB等存储引擎中。

对于表级锁,主要分为以下三类:

  1. 表锁
  2. 元数据锁
  3. 意向锁

【1】表锁

对于表锁,分为两类:

  1. 表共享读锁 (read lock)
  2. 表独占写锁 (write lock)

语法:

  1. 加锁: locktables 表名..read/write
  2. 释放锁: unlock tables/客户端断开连接

演示:

  • 加了读锁:其他包括自己客户端只能读不能写

在这里插入图片描述

【2】元数据锁:MDL

  • 元数据可以直接理解成: 表的结构
  • MDL加锁过程是系统 自动控制,无需显式使用 ,在访问一张表的时候会自动加上。MDL锁主要作用是维护表元数据的数据一致性,在表上有活动事务的时候,不可以对元数据进行写入操作
  • 在MySOL5.5中引入了MDL,当对一张表进行增删改查的时候,加MDL读锁(共享);当对表结构进行变更操作的时候,加MDL写锁(排他)。

不同SQL对应的元数据锁有所不同:
在这里插入图片描述

【3】意向锁

1.意向锁的由来

意向锁出现的场景:

  • 线程A:有一张表和客户端,我们开启事务,更新id为3的数据,会自动加上 行锁
    在这里插入图片描述

  • 此时,我们想给这张表上 表锁————显然,是做不到的,因为和原来的 行锁 冲突了
    在这里插入图片描述

  • 线程B:也就是我们想要加表锁前,就要先检查有无行锁;即 逐行检查 ,看下哪一行加了行锁, 这种方式性能很低
    -

  • 于是乎,为了提高性能,让我们在检查时不用 逐行检查 ——我们加入了 意向锁

意向锁加入以后的情况:

  • 线程A:有一张表和客户端,我们开启事务,更新id为3的数据,会自动加上 行锁
  • 在此基础上,再给表加上一个 意向锁
  • 线程B: 我们想加一个表锁,我们先看有无意向锁,再看所要加的表锁与原来的意向锁是否兼容(读/写锁) ,不兼容则进入阻塞状态,直到线程A提交

在这里插入图片描述

2.意向锁的相关语法(意向共享锁&意向排他锁)(包含语法和演示)

  1. 意向共享锁(IS): 与表锁共享锁(read)兼容 与表锁排它锁(write)互斥
  2. 意向排他锁(IX): 与表锁共享锁(read)及排它锁(write)都互斥 。意向锁之间不会互斥。

查看查看意向锁及行锁的加锁情况:

select object schema,object name,index name,lock type,lock mode,lock data from performance schema.data locks;

演示:
- 注:TABLE 为表锁 RECORD为行锁

在这里插入图片描述

  • 如何确定加共享锁是意向锁呢?输入查看代码
  • 我们可以看到lock_mode下面表锁对应的是IS,说明加的共享锁是意向共享锁

在这里插入图片描述

  • 我们知道,意向共享锁(IS): 与表锁共享锁(read)兼容 , 与表锁排它锁(write)互斥
  • 也就意味着此时可以加 表锁(读锁) ,而不能加 表锁(写锁)
    在这里插入图片描述

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Leetcode 100.101.110.199 二叉树相同/对称/平衡 C++实现
  • MySQL 的半同步模式
  • Python 设置Excel工作表页边距、纸张大小/方向、打印区域、缩放比例
  • 【MySQL】一文带你理清InnoDB引擎的<内部架构>(内存结构,磁盘结构,后台线程)
  • 数字图像处理【15】特征检测——SIFT特征检测
  • C语言中的预处理详解
  • 【迅为RK3568开发板】OpenHarmony学习开发系列教程(第2期 南向基础篇一)
  • JS中Object.prototype.toString方法解读
  • 链表--随机链表复制
  • python爬虫——入门
  • leetcode509:斐波那契数
  • 递归实现组合型枚举
  • 机器学习概述,深度学习,人工智能,无监督学习,有监督学习,增量学习,预处理,回归问题,分类问题
  • Redis篇一:初识Redis
  • 1.XV6环境配置
  • JS中 map, filter, some, every, forEach, for in, for of 用法总结
  • [数据结构]链表的实现在PHP中
  • 《用数据讲故事》作者Cole N. Knaflic:消除一切无效的图表
  • 07.Android之多媒体问题
  • Angular 4.x 动态创建组件
  • Apache的80端口被占用以及访问时报错403
  • CODING 缺陷管理功能正式开始公测
  • CSS中外联样式表代表的含义
  • Essential Studio for ASP.NET Web Forms 2017 v2,新增自定义树形网格工具栏
  • javascript数组去重/查找/插入/删除
  • Java到底能干嘛?
  • Java读取Properties文件的六种方法
  • Linux快速复制或删除大量小文件
  • Python实现BT种子转化为磁力链接【实战】
  • ViewService——一种保证客户端与服务端同步的方法
  • v-if和v-for连用出现的问题
  • 半理解系列--Promise的进化史
  • 聊聊hikari连接池的leakDetectionThreshold
  • 面试题:给你个id,去拿到name,多叉树遍历
  • 排序(1):冒泡排序
  • 区块链将重新定义世界
  • 深入浅出webpack学习(1)--核心概念
  • 使用parted解决大于2T的磁盘分区
  • 思考 CSS 架构
  • 一起参Ember.js讨论、问答社区。
  • 阿里云移动端播放器高级功能介绍
  • ​​​​​​​ubuntu16.04 fastreid训练过程
  • # wps必须要登录激活才能使用吗?
  • #LLM入门|Prompt#2.3_对查询任务进行分类|意图分析_Classification
  • (0)Nginx 功能特性
  • (17)Hive ——MR任务的map与reduce个数由什么决定?
  • (CPU/GPU)粒子继承贴图颜色发射
  • (el-Date-Picker)操作(不使用 ts):Element-plus 中 DatePicker 组件的使用及输出想要日期格式需求的解决过程
  • (javascript)再说document.body.scrollTop的使用问题
  • (Qt) 默认QtWidget应用包含什么?
  • (ros//EnvironmentVariables)ros环境变量
  • (备份) esp32 GPIO
  • (动手学习深度学习)第13章 计算机视觉---图像增广与微调
  • (九)c52学习之旅-定时器
  • (一)硬件制作--从零开始自制linux掌上电脑(F1C200S) <嵌入式项目>