小白学习mysql 之 innodb locks

时间:2022-08-26 10:09:43

Innodb 锁类型:

说明:本文中如无特殊说明,默认为innodb引擎,事务隔离级别为RR。

Shared and Exclusive Locks

innodb 可以通过两种方式实现行级锁定,即Shared(S) lock和Exclusive Lock (X)。以下简称为S锁和X锁。

S锁为共享锁,持有S锁的事务可以对该行进行读取操作,且其他session对该行不可修改。

X锁为排他锁,持有X锁的事务可以对该行进行修改操作。

如果一条记录被加了S锁,那么其他事务仍可以对其加S锁。

如果一条记录被加了X锁,那么其他事务不可以对其他加S锁或者X锁。

下面一些情况会加S锁:

select ... lock in share mode , insert select ( select 中扫描到的记录), update 连表更新中不进行更新的表 ,

IF EXISTS(select 中扫描到的记录 ) ,使用外键时会对父键进行锁定 ...

下面一些情况会加X锁:

select ... for update , update 中要更新的内容 ...

S锁和X锁对相同记录的加锁一定要保持合理的顺序,否则会很容易造成死锁。

另外,从支持资源并发的角度出发,写各种语句一定要注意扫描的记录数,不仅仅是效率问题,更重要的是资源的利用最大化。

正确的认识X锁和S锁,对于资源的利用以及死锁查找是非常重要的。

Intention Locks

意向锁主要是为了支持多粒度锁机制而存在的一种锁,它不是由程序员去用程序控制,而是mysql自己来控制的。

举个例子来说明mysql的意向锁:

商场的一卫生间每晚都要进行锁门,清洁工大爷每天锁门前先进去挨个检查下了五个隔断是否有人,没有人了方可把卫生间落锁。

大爷觉得每天都要这样检查太麻烦,有没有一种办法我在门外都知道里面有没有人?有一天他终于想到了一个办法,他在门外挂了一个牌子,

正面写着“没人”,反面写着“有人”,而且他给所有上卫生间的人两条准则:

1 进入卫生间前,如果牌子是“没人”,那么一定要把牌子翻过来(“有人”)。

2 离开卫生间后,要检查下5个隔断,如果有人就直接离开,没人了要把牌子翻过来(“没人”)。

传说所有人都这样做了,然后老大爷晚上锁门的时候直接看下门口的牌子就可以决定锁门与否,再也不用自己进去检查了。

在上面的例子中,假设卫生间是一个数据表,里面的每一个隔断是一个数据行,那么卫生间门外的牌子就是意向锁。

Record Locks

Record lock是锁在索引上的,即使没有数据表没有索引,mysql会锁定聚簇索引。

Gap Locks

gap锁锁住的是索引的间隙,主要为了防止幻读的发生。

例如:有一表名为gap,里面有字段c2,c2上有索引(非唯一索引),目前c2有值为 2,4,7,10,几个值。

现在开启一个连接:

1 开始事务

2 更新c2值为4的记录 : update gap set remark = 'change' where c2 = 7;

(事务未提交)

现在开启另外一个连接:

1 开启一个事务

2 此时,测试会发现

> insert gap(c2, remark)  values(3,'');
// success > insert gap(c2, remark) values(5,'');
//block > insert gap(c2, remark) values(8,'');
//block

可以看出,在更新c2=7的记录时,(4,7) 与 (7,10)之间的记录都被锁住了,不能进行插入。

现在,如果把c2的索引修改为唯一索引,再次执行上面的例子,结果又会不一样,上面的三条记录全部都可以插入。

因此,在唯一索引上加锁是不会产生gap锁的。在生产中,如果使用for update 进行记录锁定时,where后尽量使用unique字段。

RR级别下,可以通过设置系统变量innodb_locks_unsafe_for_binlog来使Gap lock 禁用(在查询或者索引被扫描的时候)。

另外,如果删除或者更新的记录是通过唯一键进行扫描的时候,将不会有gap锁产生。(因此,在进行对记录的更改时,where后面最好用主键或者唯一键扫描,避免gap锁)

Next-Key Locks

next-key lock = record lock + gap lock;

小白学习mysql 之 innodb locks的更多相关文章

  1. 小白学习mysql之索引初步

    导语 索引在数据库中的地位是及其的重要,同时要想完全的掌握索引并不是一件容易的事,需要对数据的查询原理以及计算机操作系统有深刻的认识,当然相关的算法和数据结构也是必须的.因此,这篇文章感到了一些压力, ...

  2. 小白学习mysql之优化基础(EXPLAIN的连接类型)

    ## 导语很多情况下,有很多人用各种select语句查询到了他们想要的数据后,往往便以为工作圆满结束了.这些事情往往发生在一些学生亦或刚入职场但之前又没有很好数据库基础的小白身上,但所谓闻道有先后,只 ...

  3. 小白学习mysql之存储过程的优劣分析以及接入控制

    存储过程的优劣 存储过程是一组实现特定功能的SQL语句集合,存储过程一经编译便存储在了服务器上,可以通过调用存储过程的名字以及传入相应的参数来使用存储过程.要高层次的掌握存储过程,不能觉得依葫芦画瓢, ...

  4. 小白学习mysql之函数

    ## 导语 曾经我以为,学会了select.update.insert和delete之后,我就学会了数据库~,要不是到公司看到SQL里充满了密密麻麻的的各种函数,我差点就信了~,当初的自己是多么的天真 ...

  5. 重新学习MySQL数据库9:Innodb中的事务隔离级别和锁的关系

    重新学习MySQL数据库9:Innodb中的事务隔离级别和锁的关系 Innodb中的事务隔离级别和锁的关系 前言: 我们都知道事务的几种性质,数据库为了维护这些性质,尤其是一致性和隔离性,一般使用加锁 ...

  6. 重新学习MySQL数据库7:详解MyIsam与InnoDB引擎的锁实现

    重新学习Mysql数据库7:详解MyIsam与InnoDB引擎的锁实现 说到锁机制之前,先来看看Mysql的存储引擎,毕竟不同的引擎的锁机制也随着不同. 三类常见引擎: MyIsam :不支持事务,不 ...

  7. 重新学习MySQL数据库2:『浅入浅出』MySQL 和 InnoDB

    重新学习Mysql数据库2:『浅入浅出』MySQL 和 InnoDB 作为一名开发人员,在日常的工作中会难以避免地接触到数据库,无论是基于文件的 sqlite 还是工程上使用非常广泛的 MySQL.P ...

  8. MySQL之InnoDB索引面试学习笔记

    写在前面 想要做好后台开发,终究是绕不过索引这一关的.先问自己一个问题,InnoDB为什么选择B+树作为默认索引结构.本文主要参考MySQL索引背后的数据结构及算法原理和剖析Mysql的InnoDB索 ...

  9. 《MySQL实战45讲》学习笔记4——MySQL中InnoDB的索引

    索引是在存储引擎层实现的,且在 MySQL 不同存储引擎中的实现也不同,本篇文章介绍的是 MySQL 的 InnoDB 的索引. 下文将以这张表为例开展. # 创建一个主键为 id 的表,表中有字段 ...

随机推荐

  1. python学习05——字典

    笨办法学python第39节 这节主要讲解的是字典,首先字典和列表的两个区别是: 1. 列表中可以通过数字找到列表中的元素,是数字作为索引的:字典中可以通过任何东西找到想要的元素,即字典可以将一个物件 ...

  2. Android 图片的平移和镜面和倒影效果

    在前面的文章中陆续介绍了图片的旋转与缩放,本文继续介绍关于图片的操作 图片的平移 使用下面的代码将图水平竖直方向平移10个像素 matrix.setTranslate(10, 10); 可以看到图片不 ...

  3. Jquery Easyui验证扩展,Easyui验证,Easyui校验,js正则表达式

    Jquery Easyui验证扩展,Easyui验证,Easyui校验,js正则表达式 >>>>>>>>>>>>>> ...

  4. oracle 分区表和分区索引

    很复杂的样子,自己都没有看完,以备后用 http://hi.baidu.com/jsshm/item/cbfed8491d3863ee1e19bc3e ORACLE分区表.分区索引ORACLE对于分区 ...

  5. cocos2d-x中的CCScrollView滑动体验不佳

    在最近的项目中,使用了Cocos2d-x (2.2.0版本)提供的CCScrollView来拖动一个比较大的画面,但是发现滑动体验非常不佳, 手指离开屏幕后,滑动没有惯性,一个不算太大的画面,要滑动好 ...

  6. blob 和 sas

    Blob是什么? 请看上篇文章简单总结下关于blob的图片上传 在使用Blob图片上传的时候碰到许多问题,比如如何使用用户名密码下载文件啊什么的 今天就记录一下我碰到的最大的问题 如何匿名去访问你上传 ...

  7. CodeForces-747C

    直接模拟就行,用一个数组保存某个server上次是在哪个task里面即可很方便判断它现在是否可用. AC代码: #include<cstdio> #include<cstring&g ...

  8. 【62】Spring总结之bean(3)

    Spring核心机制:依赖注入 Java应用(从applets的小范围到全套n层服务端企业应用)是一种典型的依赖型应用,它就是由一些互相适当地协作的对象构成的.因此,我们说这些对象间存在依赖关系.加入 ...

  9. &&num;127827&semi; 移动端调试工具之vconsole的使用~ &&num;127827&semi;

    这里以在vue项目中的使用为例⬇️ 嗯模块化的. 不消多说,先cnpm install vconsole -S 然后在mian.js中配置之- ok啦-- 开发混合app的筒子,使用mac的话也有别的 ...

  10. 从零开始学 Web 之 Vue&period;js(三)Vue实例的生命周期

    大家好,这里是「 从零开始学 Web 系列教程 」,并在下列地址同步更新...... github:https://github.com/Daotin/Web 微信公众号:Web前端之巅 博客园:ht ...