『MySQL 实战 45 讲』19 - 为什么我只查一行的语句,也执行这么慢?

为什么我只查一行的语句,也执行这么慢?

  1. 需求:创建一个表,有两个字段 id 和 c,并且在里面插入了 10 万行记录
CREATE TABLE `t` (`id` int(11) NOT NULL,`c` int(11) DEFAULT NULL,PRIMARY KEY (`id`)
) ENGINE=InnoDB;delimiter ;;
create procedure idata()
begindeclare i int;set i=1;while(i<=100000) doinsert into t values(i,i);set i=i+1;end while;
end;;
delimiter ;call idata();

查询长时间不返回

  1. 执行下面语句,长时间不返回
select * from t where id=1;
  1. 大概率是表 t 被锁住了,需要通过执行 show processlist 命令,查看语句得状态

等 MDL 锁

  1. 使用 show processlist 命令查看 Waiting for table metadata lock
    在这里插入图片描述
  2. 出现这个状态表示的是,现在有一个线程正在表 t 上请求或者持有 MDL 写锁,把 select 语句堵住了
  3. 复现场景
    在这里插入图片描述
  4. 解决办法就是找到持有 MDL 写锁的线程,然后 kill 掉
  • 通过 show processlist 只能看到 Command 是 “sleep”
  • 需要设置 performance_schema=on(相比于设置为 off 会有 10% 左右的性能损失,查询 sys.schema_table_lock_waits 表,找到 process id
# 查询是否开启
show variables like 'performance_schema'
# 找到有 MDL 写锁的线程
select blocking_pid from sys.schema_table_lock_waits;

等 flush

  1. MYSQL 里面对表做 flush 操作一般有以下两个
# 只关闭表 t
flush tables t with read lock;
# 关闭 MySQL 里所有打开的表
flush tables with read lock;
  1. Waiting for table flush 的复现步骤
    在这里插入图片描述
  2. 通过 show processlist 可以知道结果,从而排查问题
    在这里插入图片描述

等行锁

  1. 行锁复现
    在这里插入图片描述
  2. show processlist 现场
    在这里插入图片描述
  3. 但是是查不到谁在占用这个写锁,可以通过下面命令来看
select * from sys.innodb_lock_waits where locked_table='`testdb`.`t`'\G

在这里插入图片描述
4. 可以看出 905 号线程是问题根源,可以执行 KILL QUERY 905 或者 KILL 905

  • KILL QUERY 905:表示停止 905 号线程当前正在执行的语句,而这个方法其实是没有用的。因为占有行锁的是 update 语句,这个语句已经是之前执行完成了的,现在执行 KILL QUERY,无法让这个事务去掉 id=1 上的行锁
  • KILL 905:实际上,该命令才有效,也就是说直接断开这个连接。这里隐含的一个逻辑就是,连接被断开的时候,会自动回滚这个连接里面正在执行的线程,也就释放了 id=1 上的行锁

查询慢

  1. 扫描行数多,执行慢。通过查看慢查询日志,Rows_examined 可以看到扫描过的量
# 开启慢查询日志
SET GLOBAL slow_query_log=1;
# 查询是否开启慢查询日志
SHOW VARIABLES LIKE '%slow_query_log%';
# 设置慢查询时间
set long_query_time = 0;select * from t where c=50000 limit 1;

在这里插入图片描述
2. 扫描 1 行但是执行还是很慢的情况

  • 复现步骤,其中会话 B 执行了 100w 次
    在这里插入图片描述
  • 这时候选择执行 select * from t where id=1 会很慢,执行 select * from t where id=1 lock in share mode 会很快
  • 因为生成了 100w 个回滚日志
    在这里插入图片描述

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

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

相关文章

硬件知识积累 DP 接口简单介绍以及 DP信号飞线到显示屏的问题

1. DP 接口的介绍 定义与起源&#xff1a; DP接口是由PC及芯片制造商联盟开发&#xff0c;并由视频电子标准协会&#xff08;VESA&#xff09;标准化的数字式视频接口标准。它的设计初衷是为了取代传统的VGA、DVI和FPD-Link&#xff08;LVDS&#xff09;接口&#xff0c;以满足…

Qt QImageReader类介绍

1.简介 QImageReader 是用于读取图像文件的类。它提供了读取不同图像格式的功能&#xff0c;包括但不限于 PNG、JPEG、BMP 等。QImageReader 可以用于文件&#xff0c;也可以用于任何 QIODevice&#xff0c;如 QByteArray &#xff0c;这使得它非常灵活。 QImageReader 是一个…

323_C++_QT_QProcess执行cmd解压、压缩、删除tar.gz等等其他压缩包文件到指定目录,不需要外部库,QT自带API的就行

// decompressPath : 解压到此目录 // fileName : 解压的tar.gz文件名executeCommand(decompressPath , QString::fromStdString(fileName));// 开始解压 void executeCommand

uni-app scroll-view隐藏滚动条的小细节 兼容主流浏览器

开端 想写个横向滚动的列表适配浏览器&#xff0c;主要就是隐藏一下滚动条在手机上美观一点。 但是使用uni-app官方文档建议的::-webkit-scrollbar在目标标签时发现没生效。 .scroll-view_H::-webkit-scrollbar{display: none; }解决 F12看了一下&#xff0c;原来编译到浏览…

漏洞扫描神器:Nessus 保姆级教程(附破解步骤)

一、介绍 Nessus是一款广泛使用的网络漏洞扫描工具&#xff0c;用于发现和评估计算机系统和网络中的安全漏洞。它是一款功能强大的商业工具&#xff0c;由Tenable Network Security开发和维护。 以下是Nessus的一些主要特点和功能&#xff1a; 1. 漏洞扫描&#xff1a;Nessu…

转义字符解释

也许在一些代码中你看到 \n, \0 很纳闷是啥。其实在字符中有一组特殊的字符是转义字符&#xff0c;转义字符顾名思义&#xff1a;转变原来的意思的字符。 比如&#xff1a;我们有字符n&#xff0c;在字符串中打印的时候自然能打印出这个字符&#xff0c;如下&#xff1a; #in…

通过 API 接口,实现增值税发票智能识别

增值税发票智能识别是一项应用于财务管理和数据分析的技术&#xff0c;通过使用API接口&#xff0c;我们可以轻松地将增值税发票的各项信息进行结构化识别。本文将详细介绍如何通过API接口实现增值税发票的智能识别&#xff0c;并给出相应的代码说明。 首先&#xff0c;我们需…

自动安装环境shell脚本使用和运维基础使用讲解

title: 自动安装环境shell脚本使用和运维基础使用讲解 tags: [shell,linux,运维] categories: [开发记录,系统运维] date: 2024-3-27 14:10:15 description: 准备和说明 确认有网。 依赖程序集&#xff0c;官网只提供32位压缩包&#xff0c;手动编译安装后&#xff0c;在64位机…

Java 新手上路常见的5个经典问题,你遇到过吗?

当我们开始学习一门新的编程语言或者开发平台时&#xff0c;经常会遇到一些常见的问题。这些问题不仅是学习过程中的一部分&#xff0c;也是成长和提高的机会。 1. 空指针异常&#xff08;NullPointerException&#xff09; 空指针异常是 Java 开发中最常见的问题之一。它的产…

docker学习笔记3:VmWare CentOS7安装与静态ip配置

文章目录 一、安装CentOS71、下载centos镜像2、安装二、设置静态ip三、xshell连接centos本专栏的docker环境是在centos7里安装,因此首先需要会安装centos虚拟机。 本篇博客介绍如何在vm虚拟机里安装centos7。 一、安装CentOS7 1、下载centos镜像 推荐清华源,下载如下版本 …

OpenCV4.9去运动模糊滤镜(68)

返回:OpenCV系列文章目录&#xff08;持续更新中......&#xff09; 上一篇:OpenCV4.9失焦去模糊滤镜(67) 下一篇 :OpenCV系列文章目录&#xff08;持续更新中......&#xff09; 目标 在本教程中&#xff0c;您将学习&#xff1a; 运动模糊图像的 PSF 是多少如何恢复运动模…

2024-5-3学习笔记 继承关系拓展

一.继承与友元 友元类不能继承&#xff0c;也就是说基类友元不能访问子类私有和保护成员。简单的理解就是&#xff0c;爸爸的朋友不是儿子的朋友。 二.继承与静态成员 基类定义了static静态成员&#xff0c;则整个继承体系里面只有一个这样的成员。无论派生出多少个子类&…

Mac 更新 Homebrew软件包时提示 zsh: command not found: brew 错误

问题 通过Mac电脑更新Homebrew软件包时出现如下错误&#xff1a; xxxxxxxpiaodeMacBook-Pro ~ % brew update zsh: command not found: brew解决方案 在命令行输入如下指令&#xff1a; /bin/zsh -c "$(curl -fsSL https://gitee.com/cunkai/HomebrewCN/raw/master/H…

string(上)

目录 一、string类的简单介绍 二、string类中成员函数介绍 1.构造函数 1&#xff09;string&#xff08;&#xff09; 2&#xff09;string&#xff08;const string& str&#xff09; 3&#xff09;string&#xff08;const string& str&#xff0c;size_t pos&…

cmake的使用方法: 多个源文件的编译

一. 简介 前面一篇文章学习了针对只有一个 .c源文件&#xff0c;如何编写 CMakeLists.txt内容&#xff0c;从而使用 cmake工具如何编译工程。文章如下&#xff1a; cmake的使用方法: 单个源文件的编译-CSDN博客 本文学习针对 多个 .c源文件&#xff0c; CMakeLists.txt文件如…

ICode国际青少年编程竞赛- Python-1级训练场-基础训练1

ICode国际青少年编程竞赛- Python-1级训练场-基础训练1 1、 Dev.step(4)2、 Dev.step(-4) Dev.step(8)3、 Dev.turnLeft() Dev.step(4)4、 Dev.step(3) Dev.turnLeft() Dev.step(-1) Dev.step(4)5、 Dev.step(-1) Dev.step(3) Dev.step(-2) Dev.turnLeft() Dev.step(…

ICode国际青少年编程竞赛- Python-1级训练场-路线规划

ICode国际青少年编程竞赛- Python-1级训练场-路线规划 1、 Dev.step(3) Dev.turnLeft() Dev.step(4)2、 Dev.step(3) Dev.turnLeft() Dev.step(3) Dev.step(-6)3、 Dev.step(-2) Dev.step(4) Dev.turnLeft() Dev.step(3)4、 Dev.step(2) Spaceship.step(2) Dev.step(3)5、…

笔试强训-day17_T3 比那名居的桃子

一、题目链接 比那名居的桃子 二、题目描述 小红有一天看到了一只桃子&#xff0c;由于桃子看上去就很好吃&#xff0c;小红很想把它吃掉。 已知吃下桃子后&#xff0c;每天可以获得 &#x1d44e;&#x1d456;的快乐值&#xff0c;但是每天会获得b&#x1d456;的羞耻度。桃…

AnaTraf网络流量分析仪:全面把控网络运行现状,智慧诊断网络性能瓶颈

背景 在当今瞬息万变的数字时代,网络流量的高效监控和精准分析已成为企业、学校等各个行业不可或缺的基本需求。作为专业的网络流量分析设备,AnaTraf网络流量分析仪凭借其优异的性能,正成为网络管理者的得力助手。 全流量回溯分析,全方位掌握网络运行现状 网络是一个复杂的有…

[Linux][网络编程][HTTPS]详细讲解

目录 1.HTTPS介绍2.HTTP与HTTPS3."加密"是什么&#xff1f;1.加密相关术语2.为什么需要HTTPS&#xff0c;为什么需要加密&#xff1f; 4.常见的加密方式1.对称加密2.非对称加密3.数据摘要 && 数据指纹4.数字签名 5.深入探究HTTPS工作方案1.方案一&#xff1a…