首页 > 数据库 >MySQL----表级锁&行级锁&排它锁和共享锁&意向锁

MySQL----表级锁&行级锁&排它锁和共享锁&意向锁

时间:2024-06-21 18:59:08浏览次数:30  
标签:行级 事务 加锁 ---- 意向锁 MySQL 共享 表级

MySQL的锁机制

锁(Locking)是数据库在并发访问时保证数据一致性和完整性的主要机制。在 MySQL 中,不同存储引擎使用不同的加锁方式;我们以 InnoDB 存储引擎为例介绍 MySQL 中的锁机制,其他存储引擎中的锁相对简单一些。

表级锁&行级锁

表级锁:对整张表加锁。开销小,加锁快,不会出现死锁;锁粒度大,发生锁冲突的概率高,并发度低。—MyISAM
行级锁:对某行记录加锁。开销大,加锁慢,会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度高。—InnoDB

特点:

  • InnoDB 存储引擎同时支持行级锁(row-level locking)和表级锁(table-level locking),默认情况下采用行级锁。
  • 表级锁适用于并发较低、以查询为主的应用,例如中小型的网站;MyISAM 和 MEMORY 存储引擎采用表级锁。
  • 行级锁适用于按索引条件高并发更新少量不同数据,同时又有并发查询的应用,例如 OLTP 系统;InnoDB 和 NDB 存储引擎实现了行级锁。

排它锁&共享锁

排它锁(Exclusive),又称为X 锁,写锁。 允许获得该锁的事务更新或删除数据行(写锁),同时阻止其他事务取得该数据行上的共享锁和排他锁。
共享锁(Shared),又称为S 锁,读锁。 允许获得该锁的事务读取数据行(读锁),同时允许其他事务获得该数据行上的共享锁,并且阻止其他事务获得数据行上的排他锁。

X和S锁之间有以下的关系: SS可以兼容的,XS、SX、XX之间是互斥的。
一个事务对数据对象 O 加了 S 锁,可以对 O 进行读取操作但不能进行更新操作。加锁期间其它事务能对 O 加 S 锁但不能加 X 锁。
一个事务对数据对象 O 加了 X 锁,就可以对 O 进行读取和更新。加锁期间其它事务不能对 O 加任何锁。
显示加锁: select … lock in share mode强制获取共享锁,select … for update获取排它锁。
在这里插入图片描述

意向锁

要获取一张的共享锁S或者排它锁X,如何确定这张表没有被其它事务获取过X锁!!并且如果这张表里有1千万数据,如何确定里面得数据没有被其它事务获取过行锁 X锁!一行一行的扫描带来的效率过低问题如何解决? 为此,InnoDB 引入了另外一种锁:意向锁(Intention Lock)。
本身就是表锁,解决上述的效率问题。当要获取表得X锁的,不需要再检査表中的哪些行锁被(X或者S)占用,只需要快速检査IX和IS锁即可!

意向共享锁和意向排他锁

意向共享锁(IS锁): 事务计划给记录加行共享锁,事务在给一行记录加共享锁前,必须先取得该表的IS锁。
意向排他锁(IX锁): 事务计划给记录加行排他锁,事务在给一行记录加排他锁前,必须先取得该表的IX锁。
此时,事务 A 必须先申请该表的意向共享锁,成功后再申请数据行的行锁。事务 B 申请表锁时,数据库查看该表是否已经被其他事务加上了表级锁;如果发现该表上存在意向共享锁,说明表中某些数据行上存在共享锁,事务 B 申请的写锁会被阻塞。

表级锁和表级意向锁的兼容性:

在这里插入图片描述

  1. 意向锁是由InnoDB存储引擎获取行锁之前自己获取的
  2. 意向锁之间都是兼容的,不会产生冲突
  3. 意向锁存在的意义是为了更高效的获取表锁(表格中的X和S指的是表锁,不是行锁!!!)
  4. 意向锁是表级锁,协调表锁和行锁的共存关系。主要目的是显示事务正在锁定某行或者试图锁定某行。

标签:行级,事务,加锁,----,意向锁,MySQL,共享,表级
From: https://blog.csdn.net/m0_73537205/article/details/139730827

相关文章

  • webshell总结
    一、webshell概况1.webshell概念:经常有客户的网站碰到被上传小马和大马,这里的“马”是木马的意思,可不是真实的马。通常,攻击者利用文件上传漏洞,上传一个可执行并且能被解析的脚本文件,通过这个脚本来获得服务器端执行命令的能力,也就是我们经常听到的WebShell,而这个脚本文件就......
  • 6.21-二叉搜索树的最近公共祖先
    235.二叉搜索树的最近公共祖先题意描述:给定一个二叉搜索树,找到该树中两个指定节点的最近公共祖先。百度百科中最近公共祖先的定义为:“对于有根树T的两个结点p、q,最近公共祖先表示为一个结点x,满足x是p、q的祖先且x的深度尽可能大(一个节点也可以是它自己的祖先)。”......
  • 使用 GCD 实现属性的多读单写
    使用GrandCentralDispatch(GCD)实现多读单写的属性首先需要确保在多线程环境下的线程安全性。可以使用GCD提供的读写锁机制dispatch_rwlock_t或者dispatch_queue_t来实现这个功能。Swift版本的实现怎样创建一个并发队列?//使用Swift来实现的首个好处就是:......
  • 代码随想录Day1-二分查找法|快慢指针
    二分查找题目链接二分查找是一个较为基础的查找方式,对一个有序没有重复值的数组进行查找时,能够提供一个较好的时间复杂度\(O(log(n))\)算法概要对于有序并且没有重复值的数组来说,我们可以首先选定整个数组的中间下标,它的值则称为中间值,通过它把大数组分成两个小的数组,其中一个......
  • JAVA每日总结day6.21
    ok了家人们,今天我们学习了面向对象中关键字的使用和抽象类,话不多说,我们一起看看吧,(今天终于星期五了,芜湖!!!)一,this和super关键字1,this关键字的三种用法1.1this的意义 this:表示当前对象this可以访问:本类的成员属性、成员方法、构造方法;1.2 this.成员变量(第一种)......
  • MySQL----彻底卸载(附带每一步截图)
    停止mysql服务打开任务管理器,点击服务,找到mysql服务,这里我的是MySQL57,找到mysql服务后选中,点击右键选择停止服务删除mysql服务win+R打开命令框,输入cmd打开cmd控制台或者电脑左下角输入cmd搜索,选择管理员身份进入cmd控制台(否则会拒绝访问),弹出是否允许该应用对设备进行修......
  • JavaScript算法之龟兔赛跑
    简介:龟兔赛跑算法,又称弗洛伊德循环检测算法,是一种在链表中非常常用的算法。它基于运动学和直觉的基本定律。本文旨在向您简要介绍该算法,并帮助您了解这个看似神奇的算法。假设高速公路上有两辆车。其中一辆的速度为x,另一辆的速度为2x。它们唯一能相遇的条件是它们都在循环......
  • 批量归一化教学文章概要
    由于篇幅限制,我将提供一篇简洁的教学文章概要,包括关键概念和示例代码,来介绍批量归一化(BatchNormalization)。批量归一化教学文章概要引言深度学习模型在训练过程中常常面临梯度消失或爆炸的问题,这会导致模型训练缓慢或不稳定。批量归一化(BatchNormalization)是一种有效的......
  • 自然语言处理(NLP)概述
    自然语言处理(NLP)概述目录引言NLP基础词汇语法分析词嵌入NLP任务文本分类情感分析命名实体识别机器翻译文本生成问答系统NLP技术规则基础方法统计方法深度学习方法NLP工具和库NLTKspaCyStanfordNLPTransformersNLP应用语音助手聊天机器人内容推荐NLP挑战语言多......
  • 高效管理大型项目:Yarn 在复杂依赖安装中的实践与技巧
    Yarn是一个现代的包管理工具,它通过提高速度、可靠性和安全性,极大地改善了JavaScript项目中依赖的管理。对于大型项目,依赖数量可能非常庞大,这就需要一些高级技巧来确保依赖安装的效率和稳定性。本文将详细介绍如何在Yarn中处理大型项目的依赖安装。大型项目依赖管理的......