MySQL for update锁表还是锁行校验

select * from user where id = 1 for update ;

1. for update作用

在MySQL中,使用for update子句可以对查询结果集进行行级锁定,以便在事务中对这些行进行更新或者防止其他事务对这些行进行修改。

当使用for update时,锁定行的方式取决于where中的字段是否具有索引,而不是唯一索引。如果where

条件中的字段具有索引(无论是普通索引还是唯一索引),MySQL将锁定与查询结果集匹配的行,如果where中的字段没有索引MySQL将锁表

2. 撸代码证明结果

创建一张表

其中id是主键,user_name建立索引

create table if not exists user
(id        int auto_increment comment '主键ID'primary key,user_name varchar(32) null comment '用户名',password  varchar(64) null comment '密码',phone     varchar(11) null comment '手机号'
);create index user_user_name_indexon test1.user (user_name);

插入三条数据

INSERT INTO user (id, user_name, password, phone) VALUES (1, '小明', '123', '13123920201');
INSERT INTO user (id, user_name, password, phone) VALUES (2, '小王', '1234', '13123920202');
INSERT INTO user (id, user_name, password, phone) VALUES (3, '小狗', '12345', '13123920203');

begin:表示开启一个事物

commit:表示提交事物

新开3个查询窗口

窗口1

begin;
select * from user where id = 1 for update ;
commit;

窗口2

begin;
select * from user where id = 1 for update ;
commit;

窗口3

begin;
select * from user where id = 2 for update ;
commit;

a. 查询带普唯一引字段

步骤1: 窗口1执行下面代码

begin;
select * from user where id = 1 for update ;

结果如下

img

这时id = 1的行应该被锁住了

步骤2: 窗口2执行下面代码

begin;
select * from user where id = 1 for update ;

结果如下,一直在等待

img

最后报锁超时错误

img

证明id = 1的行被锁住了

步骤3:

查询id=2的数据

begin;
select * from user where id = 2 for update ;

可以查到结果

img

说明select * from user where id = 1 for update ;只锁了id = 1的行,id = 2行没有被锁

步骤4:

窗口1执行下面代码

commit;

结果如下

img

窗口2再执行下面代码

begin;
select * from user where id = 1 for update ;

这时就可以查出结果来了

img

说明id = 1行锁被释放,窗口2就可以查到结果了

证明唯一索引锁行

b. 查询带普通索引字段

窗口1

begin;
select * from user where user_name = '小明' for update ;

img

窗口2

begin;
select * from user where user_name = '小王' for update ;

img

证明普通索引时锁行

c. 查询没索引字段

窗口1:

begin;
select * from user where phone = 13123920201 for update ;

img

窗口2:

begin;
select * from user where id = 2 for update ;

img

一直再查询

img

锁等待超时

证明没索引时锁表

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

爬虫工作量由小到大的思维转变---<第四十一章 Scrapy Redis 转mysql数据连通问题>

前言: 在实际开发中,有时候我们需要将爬虫数据存储到MySQL数据库中。前面的文章已经介绍过如何让多台机器之间连通Redis, 爬虫工作量由小到大的思维转变---<第三十章 Scrapy Redis 第一步(配置同步redis)>-CSDN博客 在本章中我…

模板讲解之进阶

在之前的C入门的博客中我们就学习到了模板初阶,今天我们来学习模板的进阶,以便于更好地将模板运用到代码中 非类型模板参数 模板参数分类类型形参与非类型形参。 类型形参即:出现在模板参数列表中,跟在class或者typename之类的…

功率信号的频谱

目录 1. 前言2. 功率信号的频谱3. 参考资料 1. 前言 知识点1:函数周期性判定定理   假设函数 f ( x ) f(x) f(x) 和函数 g ( x ) g(x) g(x) 均为周期性函数,其最小正周期分别为 T f T_f Tf​ 和 T g T_g Tg​,若 T f / T g T_f/T_g T…

【软件工程】建模工具之开发各阶段绘图——UML2.0常用图实践技巧(功能用例图、静态类图、动态序列图状态图活动图)

更多示例图片可以参考:(除了常见的流程图,其他都有) 概念:类图 静态:用例图 动态:顺序图&状态图&活动图 1、【面向对象】UML类图、用例图、顺序图、活动图、状态图、通信图、构件图、部…

Linux实验记录:使用vsftpd服务传输文件

前言: 本文是一篇关于Linux系统初学者的实验记录。 参考书籍:《Linux就该这么学》 实验环境: VmwareWorkStation 17——虚拟机软件 RedHatEnterpriseLinux[RHEL]8——红帽操作系统 备注: 为了解决在多样复杂的设备之间解决传…

Mybatis 自定义ResultHandler(结果处理器)正确使用姿势

阅读指引 一、使用场景二、前提条件三、源码对照四、使用示例目标实现方式 一、使用场景 对Mybatis查询的结果集进行统一批量处理,如进行类型转换、数据变更等等。 二、前提条件 必须是查询语句。mapper方法的返回值必须是void,这也就是不能直接从这个…

【Java】SpringBoot集成freemarker|这下总该学会了吧

目录 什么是Freemarker? 常用的java模板引擎还有哪些? 环境搭建&&快速入门 代码层级结构: pom.xml如下 配置文件application.yml 创建实体类 创建模板 创建controller 创建启动类 测试 freemarker基础 基础语法种类 集合指令(List和…

有趣的CSS - 输入框选中交互动效

页面效果 此效果主要使用 css 伪选择器配合 html5 required 属性来实现一个简单的输入框的交互效果。 此效果可适用于登录页入口、小表单提交等页面,增强用户实时交互体验。 核心代码部分,简要说明了写法思路;完整代码在最后,可直…

备战蓝桥杯---数据结构与STL应用(入门1)

话不多说,直接看题: 下面为分析:显然,我们要先合并最小的两堆(因为他们在后边也得被计算,换句话,我们独立的看,某一堆的体力值为他自己重量*从现在到最后的次数) 因此&a…

26元/月起!腾讯云一键自动搭建4核16G幻兽帕鲁服务器

腾讯云无需任何配置自动搭建幻兽帕鲁游戏联机服务器,游戏24小时在线,4核16G游戏联机服务器低至26元/月起,新手小白也能一键搭建属于自己的幻兽帕鲁游戏联机服务器! 第一步:购买游戏联机服务器 购买入口:htt…

Vue3 函数式弹窗优化

背景 前面文章介绍了如何使用 函数式弹窗,弹窗方式是挂载在了全局,使用了getCurrentInstance方法拿到了全局上下文,进而拿到挂载的dialog进行弹窗操作。getCurrentInstance现在已被官方Vue API隐藏,为内部使用函数,现…

Ruoyi-Cloud-Plus_Nacos配置服务漏洞CVE-2021-29441_官方解决方法以及_修改源码解决---SpringCloud工作笔记199

CVE-2021-29441 这个漏洞是Nacos的,通过使用postman,直接访问接口: 就可以直接添加nacos的用户 Nacos是Alibaba的一个动态服务发现、配置和服务管理平台。攻击者通过添加Nacos-Server的User-Agent头部将可绕过(nacos.core.auth.enabled=true)鉴权认证,从而进行API操作。 …