【mysql】- 锁篇(上)
回顾
问题
- 事务并发执行时可能带来各种问题,并发事务访问相同记录的情况大致可以划分为3种
读-读情况:即并发事务相继读取相同的记录- 读取操作本身不会对记录有什么影响,并不会引起什么问题,所以允许这种情况的发
 
写-写情况:即并发事务相继对相同的记录做出改动- 任何一种隔离级别都不允许这种问题的发生。所以在多个未提交事务相继对一条记录做改动时,需要让它们排队执行,这个排队的过程其实是通过
锁来实现的。这个所谓的锁其实是一个内存中的结构,在事务执行前本来是没有锁的,也就是说一开始是没有锁结构和记录进行关联的 
- 任何一种隔离级别都不允许这种问题的发生。所以在多个未提交事务相继对一条记录做改动时,需要让它们排队执行,这个排队的过程其实是通过
 读-写或写-读情况:也就是一个事务进行读取操作,另一个进行改动操作- 这种情况下可能发生
脏读、不可重复读、幻读的问题 
- 这种情况下可能发生
 
 
解决上述问题方案
- 读操作利多版本并发控制( MVCC ),写操作进行
加锁 - 读、写操作都采用
加锁的方 
一致性读(Consistent Reads)
- 事务利用
MVCC进行的读取操作称之为一致性读,或者一致性性锁读,有的地也称之为快照读。所有普通的SELECT语句( plain SELECT )在READ COMMITTED、REPEATABLE READ隔离级别下都算是一致性读,一致性读并不会对表中的任何记录做加锁操作,其他事务可以自由的对表中的记录做改动 
锁定读(Locking Reads)
并发事务的
读-读情况并不会引起什么问题,不过对于写-写、读-写或写-读这些情况可能会引起一些问题,需要使用MVCC或者加锁的方式来解决它们。在使用加锁的方式解决问题时,由于既要允许读-读情况不受影响,又要使写-写、读-写或写-读情况中的操作相互阻塞
共享锁和独占锁
- 共享锁 ,英文名:
Shared Locks,简称S锁。在事务要读取一条记录时,需要先获取该记录的S锁 - 独占锁 ,也常称
排他锁,英文名:Exclusive Locks,简称X锁。在事务要改动一条记录时,需要先获取该记录的X锁 - 上述两种锁的场景
- 假如事务
T1首先获取了一条记录的S锁之后,事务T2接着也要访问这条记录:- 如果事务
T2想要再获取一个记录的S锁,那么事务T2也会获得该锁,也就意味着事务T1和T2在该记录上同时持有S锁 - 如果事务
T2想要再获取一个记录的X锁,那么此操作会被阻塞,直到事务T1提交之后将S锁释放掉 
 - 如果事务
 - 如果事务
T1首先获取了一条记录的X锁之后,那么不管事务T2接着想获取该记录的S锁还是X锁都会被阻塞,直到事务T1提交 - 故我们说
S锁和S锁是兼容的,S锁和X锁是不兼容的,X锁和X锁也是不兼容的 
 - 假如事务
 
- 共享锁 ,英文名:
 锁定读的语句
- 在采用
加锁方式解决脏读、不可重复读、幻读这些问题时,读取一条记录时需要获取该下该记录的S锁,其实这是不严谨的,有时候想在读取记录时就获取记录的X锁,来禁用别的事务读写该记录- 对读取的记录加
S锁:- 也就是在普通的
SELECT语句后边加,如果当前事务执行了该语句,那么它会为读取到的记录加S锁,这样允许别的事务继续获取这些记录的S锁(比方说别的事务也使用语句来读取这些记录),但是不能获取这些记录的X锁(比方说使SELECT ... FOR UPDATE语句来读取这些记录,或者直接修改这些记录)。如果别的事务想要获取这些记录的X锁,那么它们会阻塞,直到当前事务提交之后将这些记录上的S锁释放掉 
 - 也就是在普通的
 - 对读取的记录加
X锁:SELECT ... FOR UPDATE;也就是在普通的SELECT语句后边加FOR UPDATE,如果当前事务执行了该语句,那么它会为读取到的记录加X锁,这样既不允许别的事务获取这些记录的S锁(比方说别的事务使用语句来读取这些记录),也不允许获取这些记录的X锁(比方说使用SELECT ... FOR UPDATE语句来读取这些记录,或者直接修改这些记录)。如果别的事务想要获取这些记录的S锁或者X锁,那么它们会阻塞,直到当前事务提交之后将这些记录上的X锁释放掉
 
 - 对读取的记录加
 
- 在采用
 写操作
- 平常所用到的
写操作是DELETE、UPDATE、INSERT这三种:- DELETE:对一条记录做
DELETE操作的过程其实是先在B+树中定位到这条记录的位置,然后获取一下这条记录的X锁,然后再执行delete mark操作。我们也可以把这个定位待删除记录在B+树中位置的过程看成是一个获取X锁的锁定读 - UPDATE:
- 在对一条记录做
UPDATE操作时分为三种情况:- 如果未修改该记录的键值并且被更新的列占用的存储空间在修改前后未发生变化,则先在
B+树中定位到这条记录的位置,然后再获取一下记录的X锁,最后在原记录的位置进行修改操作。其实我们也可以把这个定位待修改记录在B+树中位置的过程看成是一个获取X锁的锁定读 - 如果未修改该记录的键值并且至少有一个被更新的列占用的存储空间在修改前后发生变化,则先在
B+树中定位到这条记录的位置,然后获取一下记录的X锁,将该记录彻底删除掉(就是把记录彻底移入垃圾链表),最后再插入一条新记录。这个定位待修改记录在B+树中位置的过程看成是一个获取X锁的锁定读,新插入的记录由INSERT操作提供的隐式锁进行保护 - 如果修改了该记录的键值,则相当于在原记录上做
DELETE操作之后再来一次INSERT操作,加锁操作就需要按照DELETE和INSERT的规则进行了 
 - 如果未修改该记录的键值并且被更新的列占用的存储空间在修改前后未发生变化,则先在
 
 - 在对一条记录做
 - NSERT:一般情况下,新插入一条记录的操作并不加锁,通过一种称之为
隐式锁来保护这条新插入的记录在本事务提交前不被别的事务访问 
 - DELETE:对一条记录做
 
- 平常所用到的
 
前边提到的
锁都是针对记录的,也可以被称之为行级锁或者行锁,对一条记录加锁影响的也只是这条记录而已,我们就说这个锁的粒度比较细;其实一个事务也可以在表级别进行加锁,自然就被称之为表级锁或者表锁,对一个表加锁影响整个表中的记录,我们就说这个锁的粒度比较粗。给表加的锁也可以分为共享锁(S锁)和独占锁(X锁)
- 多粒度锁
- 给表加
S锁:- 如果一个事务给表加了
S锁,那么:- 别的事务可以继续获得该表的
S锁 - 别的事务可以继续获得该表中的某些记录的
S锁 - 别的事务不可以继续获得该表的
X锁 - 别的事务不可以继续获得该表中的某些记录的
X锁 
 - 别的事务可以继续获得该表的
 
 - 如果一个事务给表加了
 - 给表加
X锁:- 如果一个事务给表加了
X锁(意味着该事务要独占这个表),那么:- 别的事务不可以继续获得该表的
S锁 - 别的事务不可以继续获得该表中的某些记录的
S锁 - 别的事务不可以继续获得该表的
X锁 - 别的事务不可以继续获得该表中的某些记录的
X锁 
 - 别的事务不可以继续获得该表的
 
 - 如果一个事务给表加了
 
 - 给表加
 
【mysql】- 锁篇(上)的更多相关文章
- 精通MySQL之锁篇
		
老刘是即将找工作的研究生,自学大数据开发,一路走来,感慨颇深,网上大数据的资料良莠不齐,于是想写一份详细的大数据开发指南.这份指南把大数据的[基础知识][框架分析][源码理解]都用自己的话描述出来,让 ...
 - (6)MySQL进阶篇SQL优化(MyISAM表锁)
		
1.MySQL锁概述 锁是计算机协调多个进程或线程并发访问某一资源的机制.在数据库中,除传统的计算资源 (如 CPU.RAM.I/O 等)的抢占以外,数据也是一种供许多用户共享的资源.如何保证数 据并 ...
 - MySQL优化篇系列文章(二)——MyISAM表锁与InnoDB锁问题
		
我可以和面试官多聊几句吗?只是想... MySQL优化篇系列文章(基于MySQL8.0测试验证),上部分:优化SQL语句.数据库对象,MyISAM表锁和InnoDB锁问题. 面试官:咦,小伙子,又来啦 ...
 - 「MySQL高级篇」MySQL锁机制 && 事务
		
大家好,我是melo,一名大三后台练习生,最近赶在春招前整理整理发过的博客~! 引言 锁锁锁,到哪到离不开这桩琐事,并发琐事,redis琐事,如今是MySQL琐事,这其中琐事,还跟MySQL另一个重要 ...
 - v79.01 鸿蒙内核源码分析(用户态锁篇) | 如何使用快锁Futex(上) | 百篇博客分析OpenHarmony源码
		
百篇博客分析|本篇为:(用户态锁篇) | 如何使用快锁Futex(上) 进程通讯相关篇为: v26.08 鸿蒙内核源码分析(自旋锁) | 当立贞节牌坊的好同志 v27.05 鸿蒙内核源码分析(互斥锁) ...
 - 手把手教你定位线上MySQL锁超时问题,包教包会
		
昨晚我正在床上睡得着着的,突然来了一条短信. 什么?线上的订单无法取消! 我赶紧登录线上系统,查看业务日志. 发现有MySQL锁超时的错误日志. 不用想,肯定有另一个事务正在修改这条订单,持有这条订单 ...
 - mysql锁
		
锁是计算机协调多个进程或线程并发访问某一资源的机制.在数据库中,除传统的计算资源(如CPU.RAM.I/O等)的争用以外,数据也是一种供许多用户共享的资源.如何保证数据并发访问的一致性.有效性是所有数 ...
 - MySQL锁系列3 MDL锁
		
http://www.cnblogs.com/xpchild/p/3790139.html MySQL为了保护数据字典元数据,使用了metadata lock,即MDL锁,保证在并发的情况下,结构 ...
 - Mysql锁机制--索引失效导致行锁变表锁
		
Mysql 系列文章主页 =============== Tips:在阅读本文前,最好先阅读 这篇(Mysql锁机制--行锁)文章~ 在上篇文章中,我们看到InnoDB默认的行锁可以使得操作不同行时不 ...
 - 07: mysql锁和事物隔离
		
MySQL其他篇 目录: 1.1 MySQL中的事物 1.2 mysql中锁 1.1 MySQL中的事物返回顶部 1.InnoDB事务原理 1. 事务(Transaction)是数据库区别于文件系统的 ...
 
随机推荐
- idea 2018版/2019版的破解
			
idea 2019版破解的穿越隧道:https://www.jianshu.com/p/09c9afae9a05 idea 2018版破解的穿越隧道:https://www.jianshu.com/p ...
 - elk4
			
传统问题: 微服务系统下服务器数量过大,如果还在使用依次登录每台机器的传统方法查询日志,这样效率非常低下.ELK 是elastic公司提供的一套完整的日志收集以及展示的解决方案,是三个产品的首字母缩写 ...
 - shell编程之系统环境变量2
			
本课程是<Tony老师聊shell——变量>课程的延续,主要介绍Linux shell编程基础中的运算符.包括declare命令.数值运算方法和变量测试.首先在declare命令中介绍了数 ...
 - 3、尚硅谷_SSM高级整合_使用ajax操作实现增加员工的功能
			
20.尚硅谷_SSM高级整合_新增_创建员工新增的模态框.avi 1.接下来当我们点击增加按钮的时候会弹出一个员工信息的对话框 知识点1:当点击新增的时候会弹出一个bootstrap的一个模态对话框 ...
 - php - 如何解决CURL错误( 7 ): 无法连接到主机?
			
php - 如何解决CURL错误( 7 ): 无法连接到主机? 1. 问题描述 调用第三方接口,本地调用一切ok,线上调用失败! 本地通过curLRequest()方法调用第三方接口时,curl_er ...
 - 近期Java高级开发岗面试总结
			
原文出处:公众号:编程大道 作者:walking 近期Java高级开发岗面试总结 哈喽大家好,我是walking,这是我的公众号:编程大道. 很久没和大家见面了,文章更新的速度略有延后.这个公众号断断 ...
 - 基于小程序请求接口 wx.request 封装的类 axios 请求
			
基于小程序请求接口 wx.request 封装的类 axios 请求 Introduction wx.request 的配置.axios 的调用方式 源码戳我 feature 支持 wx.reques ...
 - 一.前后端分离及drf实现序列化的原理
			
为什么要进行前后端分离 可pc.app.pad多端适应 SPA开发模式的流行--单页web应用(只有一html页面) 可实现前后端开发职责清(不分离时,前端是通过后端给的变量并渲染出来方式拿到数据! ...
 - 网页不让用户复制方法总汇,设置html禁止选择,保护源码,js禁止复制文字
			
这篇文章主要讲解:右键复制失效方法.菜单"文件"-"另存为"失效方法.防止查看源代码进行复制的方法.防止页面缓存的方法.来达到一定的代码保护效果 右键复制失效方 ...
 - css3-pointer-events_demo
			
该demo定义了一个菜单,点击了一次之后就不能再点击,另外其中也用到了flex布局,可直接将代码复制运行即可 <html> <head> <meta name=" ...