MySQL: 锁

news2024/9/25 17:16:56

一、table

CREATE TABLE `dog` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `age` int(11) DEFAULT NULL,
  `weight` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`),
  KEY `idx_age` (`age`)
) ENGINE=InnoDB AUTO_INCREMENT=51 DEFAULT CHARSET=utf8

二、插入数据:
在这里插入图片描述
三、主键上锁的测试(唯一索引和主键情况完全相同)
打开两个navicat窗口,分别执行set autocommit=0关闭自动提交。
1.在两个窗口分别执行:

select * from dog where id=35 lock in share mode;  

都不会阻塞。

2.一个窗口执行:

select * from dog where id=35 lock in share mode;  

另一个窗口执行:

select * from dog where id=35 for update;

则第二个窗口报:Lock wait timeout exceeded; try restarting transaction
3.一个窗口执行:

select * from dog where id=35 lock in share mode;  

另一个窗口执行:

update dog set weight=1111 where id=35;

则第二个窗口报:Lock wait timeout exceeded; try restarting transaction

结论:在主键上进行等值查询时,如果记录存在,则只会在记录上加记录锁。

4.一个窗口执行:

select * from dog where id=38 lock in share mode;  

id为38的记录并不存在
另一个窗口执行:

update dog set weight=1111 where id=40;

可以更新成功,但如果:

insert into dog(id,age,weight) values(37,8,32);
insert into dog(id,age,weight) values(39,8,32);


都会阻塞
结论:在主键上进行等值查询时,如果记录不存在,则只会把记录所在的区间右闭去掉,也就是加间隙锁,例如本例中,临键锁为(35,40],则实际加的为间隙锁(35,40)

5.一个窗口执行:

select * from dog where id>34 and id<40 lock in share mode;  

另一个窗口执行:

insert into dog(id,age,weight) values(32,8,32);

执行成功。
另一个窗口如果执行:

insert into dog(id,age,weight) values(38,8,32);

阻塞
结论:上述第一个查询,开始要经历2个间隙锁(30,35],(35,40]. 因为id>34这个条件命中了id=35这条记录,所以第一个间隙锁退化为记录锁,只锁定了id=35这条记录。因为id<40这个条件没有命中(35,40]这个临键锁的记录,所以临键锁退化为间隙锁(35,40),所以最终锁定的区间为[35,40),所以可以插入id 为32的数据,无法插入id为38的记录

四、普通索引上锁的测试:
1.一个窗口执行:

select * from dog where age=20 for update;

另一个窗口执行:

insert into dog(id,age,weight) values(84,17,32);

insert into dog(id,age,weight) values(85,23,32);

都阻塞。
结论:普通索引,等值查询且记录存在时,会给记录所在的区间加临键锁,同时给其下一个临键锁区间上加间隙锁。上述第一个查询,首先会给(10,20]这个区间加临键锁,然后给(20,30)这个区间加间隙锁。因此,锁定的区间为(10,30),如下的语句将不会阻塞:

update dog set weight=3 where id=10;

update dog set weight=3 where id=30;
insert into dog(id,age,weight) values(85,7,32);


2.一个窗口执行:

select * from dog where age=43 for update;

age为43的记录不存在。
锁定的为(40,50)这个开区间
另一个窗口执行:

update dog set weight=3 where id=40;

update dog set weight=3 where id=50;

都执行成功。如果执行如下语句将阻塞

insert into dog(id,age,weight) values(86,42,32);
insert into dog(id,age,weight) values(86,45,32);

结论:普通索引,等值查询,记录不存在时,锁定记录所在的开区间

3.一个窗口执行:

select * from dog where age>44 and age< 48 for update;

另一个窗口执行:

insert into dog(id,age,weight) values(86,42,32);
insert into dog(id,age,weight) values(86,49,32);

将阻塞。执行如下语句:

update dog set weight=6 where id=50;

成功。
分析:上述第一条语句锁定的是(40,50)这个开区间,也就是加了间隙锁。
如果将第一条语句改为:

select * from dog where age>23 and age<= 30 for update;

另一个窗口执行:

insert into dog(id,age,weight) values(86,22,32);

insert into dog(id,age,weight) values(86,33,32);

都会阻塞
执行如下语句:

update dog set weight=35 where id=35;

将执行成功。
分析:上述第一条语句锁定的是(20,30]这个区间和(30,35)这个区间,也就是最总锁定(20,35)这个区间。

五、没有索引的列上锁的测试:
1.一个窗口执行:

select * from dog where weight=3 for update;

另一个窗口执行:

insert into dog(id,age,weight) values(99,99,99);

则第二个窗口报:Lock wait timeout exceeded; try restarting transaction
2.一个窗口执行:

select * from dog where weight=34 for update;

另一个窗口执行:

insert into dog(id,age,weight) values(99,99,99);

则第二个窗口报:Lock wait timeout exceeded; try restarting transaction

3.一个窗口执行:

select * from dog where weight>5 for update;

另一个窗口执行:

insert into dog(id,age,weight) values(1,1,1);

则第二个窗口报:Lock wait timeout exceeded; try restarting transaction

结论:当在没有索引的列进行锁定时,不管是等值查询查到了数据、等值查询没有查到数据、范围查询,都给相当于整个表加了表锁,其它事务无法对表进行任何插入或更新操作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1026720.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++中的四种类型转换运算符

隐式类型转换是安全的,显式类型转换是有风险的,C语言之所以增加强制类型转换的语法,就是为了强调风险,让程序员意识到自己在做什么。但是,这种强调风险的方式还是比较粗放,粒度比较大,它并没有表明存在什么风险,风险程度如何。 再者,C风格的强制类型转换统一使用( ),…

linux上mysql数据备份(全量备份策略+增量备份策略)

执行备份策略前&#xff0c;先做好scp命令的准备 解决思路&#xff1a; 生成SSH公钥/私钥后&#xff0c;您需要将公钥添加到服务器上&#xff0c;从而使服务器可以使用该公钥来验证您的身份。 生成SSH公钥/私钥的命令为 ssh-keygen -t rsa -b 4096什么都不用输入&#xff0c…

用于无功补偿的固定电容晶闸管控制反应器研究(Simulink)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

已解决 (org.springframework.beans.factory.BeanCreationException)

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页: &#x1f405;&#x1f43e;猫头虎的博客&#x1f390;《面试题大全专栏》 &#x1f995; 文章图文并茂&#x1f996…

vue模板语法(下集)

事件处理器 Vue模板语法中的事件处理器是指在Vue组件中绑定DOM事件&#xff0c;当事件发生时执行相应的方法或表达式。常见的事件包括点击事件click、输入事件input、鼠标移入事件mouseover等等。 事件监听可以使用v-on 指令 2.1 事件修饰符 .Vue通过由点(.)表示的指令后缀来调…

近2万签名的句子网络签名ACCESS\EXCEL数据库

虽然已经有《24万QQ伤感签名论坛签名ACCESS数据库》和《2万多条QQ签名论坛签名大全ACCESS数据库》两个论坛签名数据&#xff0c;但是总觉得今天更正经一些&#xff0c;每个句子都可以当作一个好词好句。 分类包含&#xff1a;爱情诗&#xff08;2315&#xff09;、超级拽&#…

IMX6ULL ARM Linux开发板SD卡启动,SD卡的分区与分区格式化创建

一、确定TF卡挂载到ubuntu上的设备名称及分区情况 1. 在ubuntu不接入TF卡的情况下&#xff0c; 使用df -lh /dev/sd*命令查看当前"/dev/sd开头"的设备。 ##输入df -lh /dev/sd*命令&#xff0c;敲回车键 ~$ df -lh /dev/sd* 2.将TF卡接入到ubuntu&#xff0c;再次使…

Compose的一些小Tips - 可组合项的绘制

系列文章 Compose的一些小Tips - 可组合项的生命周期 Compose的一些小Tips - 可组合项的绘制&#xff08;本文&#xff09; Compose的一些小Tips - 列表的优化 前言 本系列介绍Compose的一些常识&#xff0c;了解这些tips并不会让人摇身一变成为大佬&#xff0c;但可以帮助到…

大数据Flink(八十四):SQL语法的DML:窗口聚合

文章目录 SQL语法的DML:窗口聚合 一、滚动窗口(TUMBLE)

R 语言画图中英文字体解决方案

在某些时候&#xff0c;需要在 R 画图中添加中文&#xff0c;但是默认情况下&#xff0c;R 对中文的支持不好。这里推荐一个 showtext 的 R 包。如果需要将含有中文字体的图形保存为 pdf 文件&#xff0c;可以使用下面讲到的方案&#xff0c;最新版的showtext已经支持了 ggplot…

6.1 使用scikit-learn构建模型

6.1 使用scikit-learn构建模型 6.1.1 使用sklearn转换器处理数据6.1.2 将数据集划分为训练集和测试集6.1.3 使用sklearn转换器进行数据预处理与降维1、数据预处理2、PCA降维算法 代码 scikit-learn&#xff08;简称sklearn&#xff09;库整合了多种机器学习算法&#xff0c;可以…

已解决 Bug: SyntaxError - expected expression, got ‘<‘

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页: &#x1f405;&#x1f43e;猫头虎的博客&#x1f390;《面试题大全专栏》 &#x1f995; 文章图文并茂&#x1f996…

C# ref 学习1

ref 关键字用在四种不同的上下文中&#xff1b; 1.在方法签名和方法调用中&#xff0c;按引用将参数传递给方法。 2.在方法签名中&#xff0c;按引用将值返回给调用方。 3.在成员正文中&#xff0c;指示引用返回值是否作为调用方欲修改的引用被存储在本地&#xff0c;或在一般…

React 全栈体系(十)

第五章 React 路由 三、基本路由使用 7. 代码 - Switch 的使用 7.1 Test /* src/pages/Test/index.jsx */ import React, { Component } from reactexport default class Test extends Component {render() {return (<div><h2>Test....</h2></div>…

拓世AI|轻松涨粉的秘密武器!从选题到配图,AI工具让你事半功倍

2023年的小红书&#xff0c;发展趋势依旧昂扬向上。 最新数据显示&#xff0c;小红书拥有逾3亿的月活用户,且超过80%的用户集中在20-30岁年龄段。这代表什么?广大的年轻用户基数和消费能力!正处于购买力上升期的年轻人,是品牌最想抓住的目标用户。巨大的红利吸引了无数人下场…

自定义开发成绩查询小程序

在当今数字化时代&#xff0c;教育行业借助技术手段提高教学效果。作为老师&#xff0c;拥有一个自己的成绩查询系统可以帮助你更好地管理学生成绩&#xff0c;并提供更及时的反馈。本文将为你详细介绍如何从零开始搭建一个成绩查询系统&#xff0c;让你的教学工作更加高效和便…

MQ - 10 RocketMQ的架构设计与实现

文章目录 导图概述RocketMQ 系统架构协议和网络模块数据存储元数据存储消息数据生产者和消费者生产端消费端HTTP 协议支持和管控操作RocketMQ 从生产到消费的全过程总结导图 概述 RocketMQ 在功能、稳定性、性能层面都比 RabbitMQ 的表现更好 RocketMQ 系统架构 先来看一下 R…

驱动开发练习,platform驱动模型的使用

一.总线模型介绍 linux中将一个挂载在总线上的驱动的驱动模型分为三部分&#xff1a;device、driver和bus&#xff1b; device部分&#xff1a;用来保存设备信息对象&#xff0c;在内核中一个klist_device链表中进行管理&#xff1b; driver部分&#xff1a;用来保存驱动信息对…

Windows:虚拟内存的使用

文章目录 简介如何开启并设置虚拟内存如何查看虚拟内存参考文献 简介 windows里什么是虚拟内存&#xff1f; 其实类似Linux里的交换内存/交换页&#xff0c;即将硬盘上一块空间作为虚拟的内存&#xff0c;当物理内存不足时&#xff0c;则可以将不常用的数据从物理内存中转移到…

如何做到人声和背景音乐分离?记住这个宝藏网站~

在这个短视频盛行的时代&#xff0c;优质的背景音乐会让视频锦上添花&#xff0c;但也会造成类似的问题&#xff1a;想单独使用视频中的某一段人声&#xff0c;但会被背景音乐扰乱视听效果。这时就需要将人声和背景音乐进行分离了&#xff0c;下面来分享一个宝藏网站&#xff0…