广告
返回顶部
首页 > 资讯 > 数据库 >MySQL的表级锁,行级锁,排它锁和共享锁是什么
  • 170
分享到

MySQL的表级锁,行级锁,排它锁和共享锁是什么

2023-07-02 17:07:38 170人浏览 泡泡鱼
摘要

这篇文章主要介绍“MySQL的表级锁,行级锁,排它锁和共享锁是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Mysql的表级锁,行级锁,排它锁和共享锁是什么”文章能帮助大家解决问题。前言先说下事

这篇文章主要介绍“MySQL的表级,行级锁,排它锁和共享锁是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Mysql的表级锁,行级锁,排它锁和共享锁是什么”文章能帮助大家解决问题。

    前言

    先说下事务是什么,因为我们业务是比较复杂的,不可能一个sql就能解决的,涉及多个sql就组成一个事务。事务就是一组sql共同执行,要么完全成功,要么完全失败,不能出现部分成功或者部分失败的情况。一个事务有ACID特性:

    • 原子性:要么全部成功,要么全部失败,这样才能保证事务的一致性;

    • 一致性:比如银行的转账,扣除一个人的钱肯定要给另一个人加钱,不能光扣除不加,这样业务就存在问题,数据的一致性就破坏了;

    • 持久性:当我们数据commit以后,数据是先写到缓存当中,缓存中的数据还是要慢慢花时间往磁盘上写,如果此时停电了、宕机或者重启了,我们有redo log重做日志来保证数据库的持久性;

    • 隔离性:这块可以说下事务为什么要有隔离性,因为事务要允许并发执行,一个业务涉及了很多事务,而我们后台往往有很多业务,要能够让他们并发执行,如果所有的事务都是串行执行的话,那这样我们写多线程程序只有一个线程来做事情,这样效率很低。所以事务要并发执行,但是并发执行涉及了一些问题:事务的安全性&一致性并发的效率问题,我们以这两个东西为参考点,才得到了mysql不同等级的并发/隔离,如果事务并发执行时我们完全不隔离的话,就可能会出现脏读(事务B读到了事务A还未提交的数据然后,然后用事务A未提交的数据去做计算,得到了很多其他的结果,然后事务A又把那个数据rollback掉,那么事务B计算出来的都是有问题的数据,脏读一定会出现问题)、不可重复读(以同样的条件去一个数据,然后再次去查询的时候发现数据的值有所改变,当然不可重复读也不一定会有问题,有些业务场景下是允许的,这和业务上数据的安全性和一致性是否严格有关)和幻读(在事务中按照同样的条件前后两次查询的结果数据量不同)这些问题。

    那么我们为了解决事务并发执行遇到的问题就给出了事务的隔离级别:

    • 串行化,串行化完全用锁来实现,通过锁给所有事务排序,按顺序执行,这样做数据的安全性高但并发的效率很低,一般我们不会这样做的。

    • 未提交读,对于我们写的多线程程序来说,对于临界区代码段没有做任何的并发控制,虽然并发性高但数据安全性很低,未提交读还允许脏读的存在,这是有问题的所以绝对不会使用未提交读。串行化和未提交读在实际项目中是不会用到的,一般数据库引擎默认工作在已提交读和可重复读,这两个隔离级别就结合了数据的安全性&一致性和数据的并发效率,这两个是由MVCC多版本并发控制机制实现的

    • 已提交读,oracle默认工作级别。不允许读取未commit的数据,这个级别仍然允许不可重复读和虚读产生。

    • 可重复读,MySQL默认工作级别。保证事务再次读取是依然得到相同的数据,部分解决了虚读,但虚读是仍然会出现的

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    注意:

    • 事务隔离级别越高,为避免冲突所花费的性能也就越多,即效率低。

    • 在“可重复读”级别,实际上可以解决部分的虚读问题,但是不能防止update更新产生的虚读问题,要禁止虚读产生,还是需要设置串行化隔离级别。

    事务隔离级别的实现原理:锁+MVCC。串行化底层实现原理是锁,锁有共享锁、排它锁、意向共享锁、意向排它锁、间隙锁和死锁,InnoDB的已提交读和可重复读的底层实现原理:mvcC(多版本并发控制),MVCC提供了一种并发读取方式,包括快照读(同一份数据会有多个版本)、当前读、undo log和redo log。MVCC是已提交读和可重复读的原理,锁是串行化的原理

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    ACD特性用事务日志实现,I 特性用共享锁、排它锁、MVCC 实现。事务日志分为undo log(回滚日志) 和 redo log(重做日志)

    一、表级锁&行级锁

    • 表级锁:对整张表加锁。开销小(因为不用去找表的某一行的记录进行加锁,要修改这张表,直接申请加这张表的锁),加锁快,不会出

    • 现死锁;锁粒度大,发生锁冲突的概率高,并发度低

    • 行级锁:对某行记录加锁。开销大(需要找到表中相应的记录,有搜表搜索引的过程),加锁慢,会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度高

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    MyISAM存储引擎只支持表级锁,InnoDB支持事务处理,支持行级锁,并发能力更好

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    二、排它锁&共享锁

    • 排它锁:又称为X锁,写锁

    • 共享锁:又称为S锁,读锁

    读读(SS)之间是可以兼容的,但是读写(SX、SX)之间,写写(XX)之间是互斥的

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    1. 测试不同事务之间排它锁和共享锁的兼容性

    我们先查看表SQL及内容

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    查看隔离级别:

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    首先开启一个事务A,给id=7的数据加上排它锁:

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    在另一个客户端开启事务B:

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    给id=7不管加排它锁和共享锁都阻塞了并没有查询出来,因为A事务给id=7这一行的数据加了排它锁,就是写锁,其他人不能读也不能写。

    总结:不同事务之间对于数据的锁,只有SS锁可以共存,XX、SX、XS都不能共存

    2. 测试行锁加在索引项上

    其实行锁是加在索引树上的。

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    每次做完测试都把刚做的rollback。

    用表的无索引字段作为过滤条件

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    那现在事务2获取不同行chenwei的记录

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    InnoDB是支持行锁的,刚才以主键id为过滤条件时,事务1和事务2获取不同行的锁是可以成功的。然而现在我们发现获取name为chenwei的排它锁也获取不到了,这是为什么?我们解释一下:

    InnoDB的行锁是通过给索引项加锁来实现的,而不是给表的行记录加锁实现的

    而我们用name作为过滤条件没有用到索引,自然就不会使用行锁,而是使用表锁。这就意味着只有通过索引检索数据,InnoDB才使用行级锁,否则InnoDB都将使用表锁!!!

    我们给name字段加上索引:

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    然后再做刚才的操作:

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    我们发现,给name加上索引后,两个事务可以获取到不同行的排它锁(for update),再一次证明了InnoDB的行锁是加在索引项上的。

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    因为现在name走的是索引, 通过zhangsan在辅助索引树上找到它所在行记录的id是7,然后到主键索引树上,获取对应行记录的排他锁(个人猜测应该是辅助索引树和主键索引树相应的记录都加了锁)

    三、串行化隔离级别测试

    串行化所有事务用的都是共享锁或者排它锁,不需用手动添加。select获取的是共享锁,insert、delete和update获取的都是排它锁。

    设置串行化隔离级别:

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    两个事务可以同时获取共享锁(SS共存:

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    现在让事务2插入数据;

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    由于Insert需要加排它锁,但是由于事务1已经对整张表加了共享锁,事务2无法再对表成功加锁(sx不共存)

    rollback一下,把所有获取锁的状态都回退掉:

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    开启两个事务:

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    因为我们给name加上了索引,以上的select相当于给name为zhangsan的数据加上了行共享锁

    事务2update;

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    事务2不能update,因为此时已经被事务1的共享锁锁住了整个表

    事务2在辅助索引树上找zhangsan,找到对应的主键值,然后去主键索引树找到相应的记录,但是发现这行记录已经被共享锁锁住了,事务2可以获取共享锁,但是不能获取排他锁

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    我们再用主键索引试试id能不能update

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    依然阻塞住了,虽然我们where后面的字段现在使用的id而不是name,但是name也是通过辅助索引树找到对应的主键,再到主键索引树上找相应的记录,而主键索引树上的记录加了锁

    我们update id=8的数据,成功了。因为我们select的时候,只是给id=7的数据加上了行锁,我们操作id=8的数据当然可以成功

    MySQL的表级锁,行级锁,排它锁和共享锁是什么

    有索引,则使用行锁;没有索引,则使用表锁。

    表级锁还是行级锁说的是锁的粒度,共享锁和排他锁说的是锁的性质,不管是表锁还是行锁,都有共享锁和排他锁的区分。

    串行化玩的就是排它锁和共享锁,在可重复读级别下,不手动加锁的话,用的就是MVCC机制,实际上并没有用到锁,我们也可以手动加锁。InnoDB如果不创建索引的话,用的是表锁,如果查询的时候用到了索引项,它用的就是行锁了,行锁是给索引加锁,而不是单纯给一行数据加锁。

    关于“MySQL的表级锁,行级锁,排它锁和共享锁是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网数据库频道,小编每天都会为大家更新不同的知识点。

    您可能感兴趣的文档:

    --结束END--

    本文标题: MySQL的表级锁,行级锁,排它锁和共享锁是什么

    本文链接: https://www.lsjlt.com/news/343601.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • MySQL的表级锁,行级锁,排它锁和共享锁是什么
      这篇文章主要介绍“MySQL的表级锁,行级锁,排它锁和共享锁是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MySQL的表级锁,行级锁,排它锁和共享锁是什么”文章能帮助大家解决问题。前言先说下事...
      99+
      2023-07-02
    • MySQL的表级锁,行级锁,排它锁和共享锁
      目录前言一、表级锁&行级锁二、排它锁&共享锁1. 测试不同事务之间排它锁和共享锁的兼容性2. 测试行锁加在索引项上三、串行化隔离级别测试前言 如果我们和面试官聊到事务的问题,怎么回答呢? 先说下事务是什么...
      99+
      2022-07-14
      MySQL表级锁 MySQL行级锁 MySQL排它锁 MySQL共享锁
    • MySQL表锁、行锁、排它锁及共享锁怎么使用
      这篇文章主要介绍“MySQL表锁、行锁、排它锁及共享锁怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MySQL表锁、行锁、排它锁及共享锁怎么使用”文章能帮助大家解决问题。一、事务隔离机制的选...
      99+
      2023-06-29
    • MySQL表锁、行锁、排它锁及共享锁的使用详解
      目录前言一、事务隔离机制的选择二、表级锁&行级锁三、排它锁(Exclusive)和共享锁(Shared)1. 测试不同事务之间排它锁和共享锁的兼容性2. 测试行锁加在索引项上...
      99+
      2022-11-13
    • MySQL中表锁,行锁,共享锁,排它锁,间隙锁的示例分析
      小编给大家分享一下MySQL中表锁,行锁,共享锁,排它锁,间隙锁的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!锁,在现...
      99+
      2022-10-18
    • MySQL的意向共享锁、意向排它锁和死锁是什么
      本篇内容介绍了“MySQL的意向共享锁、意向排它锁和死锁是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、InnoDB的表级锁在绝大多...
      99+
      2023-07-02
    • Mysql锁之行级锁和表级意向锁
      Innodb存储引擎实现了两种行级锁: l   共享锁 l   排他锁 这两种锁之间的兼容关系如下图所示 共享锁 排他锁 ...
      99+
      2022-10-18
    • MySQL的意向共享锁、意向排它锁和死锁
      目录一、InnoDB的表级锁二、意向共享锁和意向排它锁三、死锁1. 数据库中的死锁2. 死锁场景以及解决方法3. 操作三、锁的优化建议一、InnoDB的表级锁 在绝大多数情况下应该使用行锁,因为事务和行锁往往是选择Inn...
      99+
      2022-07-14
      MySQL意向共享锁 MySQL意向排它锁 MySQL死锁
    • mysql数据库中行级锁、表级锁和页级锁的区别是什么
      这篇文章主要介绍了mysql数据库中行级锁、表级锁和页级锁的区别是什么,具有一定借鉴价值,需要的朋友可以参考下。下面就和我一起来看看吧。按粒度可以分为:1、行级锁,MySQL中锁定粒度最细的一种锁,表示只针...
      99+
      2022-10-18
    • MySql的行级锁和表级锁是怎样的
      MySql的行级锁和表级锁是怎样的,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 MySql 行级锁 表级锁如何保...
      99+
      2022-10-18
    • mysql中的排它锁x和共享锁s的介绍
      这篇文章主要介绍“mysql中的排它锁x和共享锁s的介绍”,在日常操作中,相信很多人在mysql中的排它锁x和共享锁s的介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”my...
      99+
      2022-10-18
    • Mysql行级锁和页级锁的优缺点
      本篇内容介绍了“Mysql行级锁和页级锁的优缺点”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!    如果...
      99+
      2022-10-18
    • mysql表锁和行锁区别是什么
      小编给大家分享一下mysql表锁和行锁区别是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、表锁特点:偏向MyISAM存储...
      99+
      2022-10-18
    • mysql共享锁指的是什么
      小编给大家分享一下mysql共享锁指的是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1、说明共享锁,也称读锁,多用于判断数据是否存在,多个读操作可以同时进行...
      99+
      2023-06-15
    • mysql的共享锁与排他锁的区别和使用方法
      mysql锁机制分为表级锁和行级锁,本文就和大家分享一下我对mysql中行级锁中的共享锁与排他锁进行分享交流。共享锁又称为读锁,简称S锁,顾名思义,共享锁就是多个事务对于同一数据可以共享一把锁,都能访问到数...
      99+
      2022-10-18
    • mysql的锁级别是什么
      今天就跟大家聊聊有关mysql的锁级别,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。锁级别锁级别就是我们通常所说的锁粒度。锁的类型分为读锁和写锁,这...
      99+
      2022-10-18
    • MySQL的全局锁和表级锁的具体使用
      目录前言全局锁表级锁表锁元数据锁(Metadata Locking,简称:MDL锁)总结参考资料前言 在真实的企业开发环境中使用MySQL,MySQL肯定不会只有我一个人使用,而是一个团队显式的使用MySQL,或者...
      99+
      2022-05-13
      MySQL 全局锁 MySQL 表级锁
    • mysql中什么是排它锁
      本篇文章为大家展示了mysql中什么是排它锁,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1、说明排他锁 exclusive lock(也叫writer lock)又称写锁,是悲观锁的一种实现。排它...
      99+
      2023-06-15
    • MySQL数据库InnoDB引擎行级锁锁定范围是什么
      这篇文章主要介绍MySQL数据库InnoDB引擎行级锁锁定范围是什么,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!         ...
      99+
      2022-10-18
    • 解析 MySQL 锁机制:共享锁、排它锁、间隙锁、意向锁等,保障数据安全与高并发的秘密武器
      前言并发事务问题锁分类锁定读共享锁排它锁 意向排它、意向共享锁自增锁记录锁间隙锁InnoDB 行锁模式及加锁方法死锁总结 前言 MySQL 锁机制比较显而易见,其最显著的特点是不...
      99+
      2023-10-18
      mysql java 数据库
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作