MySQL中怎么看是否走了索引

article/2025/7/12 19:25:54

学生表

创建普通索引

create index index_name on student (name);

1.使用EXPLAIN查看执行计划(核心)

explain select * from student where name = '李明'

  • key字段:显示实际使用的索引名称。若值为NULL,表示未使用索引;若显示具体索引名,说明使用了对应索引。比如EXPLAIN SELECT * FROM student WHERE username = '李明',若key显示index_name ,意味着使用了name字段上的索引。

  • type字段:表示查询类型,反映查询性能,效率从高到低排序为system > const > eq_ref > ref > range > index > ALL 。ALL表示全表扫描,未使用索引;refrange等表示使用了索引,且越靠前性能越好。

  • possible_keys字段:列出可能使用的索引,与key字段对比,若possible_keys有索引但keyNULL,说明 MySQL 优化器未选择使用索引。

  • key_len字段:显示索引使用的字节数,可用于评估索引覆盖的列长度及类型,合理长度有助于判断索引是否正常使用。

  • Extra字段:包含额外信息,如Using index表示使用覆盖索引;Using where表示使用WHERE条件过滤数据;若出现Using filesort(文件排序)、Using temporary(使用临时表) ,说明查询未有效利用索引,性能可能不佳。

2.查看慢查询日志

确认慢查询日志配置

SHOW VARIABLES LIKE 'slow_query_log';         -- 是否开启慢查询日志(ON/OFF)
SHOW VARIABLES LIKE 'slow_query_log_file';    -- 日志文件路径
SHOW VARIABLES LIKE 'long_query_time';        -- 慢查询阈值(秒,默认 10 秒)

临时开启慢查询日志(测试环境)

-- 开启慢查询日志
SET GLOBAL slow_query_log = ON;
-- 设置日志文件路径(需确保路径存在且 MySQL 有写入权限)
SET GLOBAL slow_query_log_file = 'LAPTOP-RK330M4R-slow.log';  -- 确定在的路径
-- 设置慢查询阈值(如 0.1 秒,方便测试)
SET GLOBAL long_query_time = 0.1;

查看日志内容分析

使用命令行工具(如 catless)或文本编辑器打开日志文件:

less /var/lib/mysql/LAPTOP-RK330M4R-slow.log 

3.使用SHOW PROFILE(需要开启功能)

-- 开启profiling功能
SET profiling = 1;
-- 执行查询语句
SELECT * FROM student WHERE name = '李军';
-- 查看查询的执行信息
SHOW PROFILES;
-- 查看指定查询的详细执行信息
SHOW PROFILE FOR QUERY 1;  -- 替换为实际的 Query_ID
--g关闭功能
SET profiling = 1;

4、Performance Schema实时监控

SELECT DIGEST_TEXT AS 查询语句,ROWS_EXAMINED AS 扫描行数
FROM performance_schema.events_statements_summary_by_digest
WHERE DIGEST_TEXT LIKE '%student%';
  • ROWS_EXAMINED 远大于 1 → 可能未走索引,需结合 EXPLAIN 确认。

5、索引使用状态

SHOW STATUS LIKE 'Handler_read%';
  • Handler_read_rnd_next 值高 → 全表扫描多(未走索引)

总结

explain最快:直接判断结果中的key是否为NULL


http://www.hkcw.cn/article/dEUurXEldM.shtml

相关文章

<< C程序设计语言第2版 >> 练习 1-23 删除C语言程序中所有的注释语句

1. 前言 本篇文章介绍的是实现删除C语言源文件中所有注释的功能.希望可以给C语言初学者一点参考.代码测试并不充分, 所以肯定还有bug, 有兴趣的同学可以改进. 原题目是: 练习1-23 编写一个删除C语言程序中所有的注释语句. 要正确处理带引号的字符串与字符常量. 在C语言中, 注释…

数据结构与算法之中缀表达式的求值

栈 栈的一个实际需求 请输入一个表达式计算式:[7*22-51-53-3]点击计算【如下图】 栈的介绍 栈的英文为stack(stack)。栈是一个先入后出(FILO-First In Last Out)的有序列表。栈(stack)是限制线性表中元素的插入和删除只能在线性表的同一端进行的一种特殊线性表…

显卡3080和4060哪个强 两款游戏性能对比

对于硬核玩家而言,选择一款合适的显卡至关重要。在市场上,NVIDIA的3080和4060两款显卡备受关注。很多朋友在选择时会疑惑,究竟是3080更强,还是4060更具性价比呢?今天我们就来深入分析这两款显卡,帮助大家做…

Visual Studio 2022 发布独立的 exe 文件

我们在用 Visual Studio 2022 写好一个 exe 程序之后,如果想把这个拿到其他地方运行,需要把 exe 所在的文件夹一起拿过去。 编译出来的 exe 文件需要其他几个文件一同放在同一目录才能运行,原因在于默认情况下,Visual Studio 是把…

若依项目AI 助手代码解析

基于 Vue.js 和 Element UI 的 AI 助手组件 一、组件整体结构 这个 AI 助手组件由三部分组成&#xff1a; 悬浮按钮&#xff1a;点击后展开 / 收起对话窗口对话窗口&#xff1a;显示历史消息和输入框API 调用逻辑&#xff1a;与 AI 服务通信并处理响应 <template><…

Java源码中有哪些细节可以参考?(持续更新)

欢迎来到啾啾的博客&#x1f431;。 记录学习点滴。分享工作思考和实用技巧&#xff0c;偶尔也分享一些杂谈&#x1f4ac;。 有很多很多不足的地方&#xff0c;欢迎评论交流&#xff0c;感谢您的阅读和评论&#x1f604;。 目录 String的比较final的使用transient避免序列化 St…

Linux | Shell脚本的常用命令

一. 常用字符处理命令 1.1 连续打印字符seq seq打印数字&#xff1b;且只能正向打印&#xff0c;不可反向连续打印 设置打印步长 指定打印格式 1.2 反向打印字符tac cat 正向&#xff0c;tac 反向 1.3 打印字符printf printf "打印的内容"指定格式打印内容 换行…

【FlashRAG】本地部署与demo运行(二)

前文【FlashRAG】本地部署与demo运行&#xff08;一&#xff09; 下载必要的模型文件 完成了项目拉取和依赖下载后&#xff0c;我们需要进一步下载模型文件 Faiss&#xff08;Facebook AI Similarity Search&#xff09;是由Facebook AI团队开发的高效相似性搜索和密集向量聚…

火狐安装自动录制表单教程——仙盟自动化运营大衍灵机——仙盟创梦IDE

打开火狐插件页面 安装完成 使用 功能 录制浏览器操作 录入地址 开始操作 录制完成 在当今快速发展的软件开发生态中&#xff0c;自动化测试已从一种新兴技术手段&#xff0c;转变为保障软件质量与开发效率不可或缺的关键环节。其重要性体现在多个维度&#xff0c;同时&#x…

【目标检测】【AAAI-2022】Anchor DETR

Anchor DETR&#xff1a; Query Design for Transformer-Based Object Detection 锚点DETR&#xff1a;基于Transformer的目标检测查询设计 论文链接 代码链接 摘要 在本文中&#xff0c;我们提出了一种基于Transformer的目标检测新型查询设计。此前的Transformer检测器中&am…

zTasker一款Windows自动化软件,提升效率:大小仅有10MB,免费无广告

一、zTasker是什么&#xff1f; zTasker是一款发布于2023年9月的免费无广告工具&#xff0c;专为Windows用户打造。它以仅8MB的轻量体积、极低资源占用&#xff08;内存消耗不足10MB&#xff09;和秒级启动速度脱颖而出&#xff0c;堪称“任务计划程序的终极强化版”。无论是定…

数学术语之源——绝对值(absolute value)(复数模?)

目录 1. 绝对值&#xff1a;(absolute value): 2. 复数尺度(复尺度)&#xff1a;(modulus): 1. 绝对值&#xff1a;(absolute value): 一个实数的绝对值是其不考虑(irrespective)符号的大小(magnitude)。在拉丁语中具有相同意思的单词是“modulus”&#xff0c;这个单词还…

USB充电检测仪-2.USB充电检测仪硬件设计

本系列文章的最终目标是制作一个USB充电检测仪&#xff0c;支持的功能&#xff1a; 显示USB充电电压、电流、功率、充电量&#xff08;单位WH&#xff09;&#xff1b;实现Typec口和USB-A口的相互转换&#xff08;仅支持USB 2.0&#xff09;&#xff1b; 当然网上有很多卖这种…

华院计算受邀参展第九届丝绸之路国际博览会暨中国东西部合作与投资贸易洽谈会

2025年5月21日至25日&#xff0c;以“丝路融通开放合作”为主题的第九届丝绸之路国际博览会暨中国东西部合作与投资贸易洽谈会在陕西西安国际会展中心隆重召开。应上海市国内合作交流服务中心和上海科创投集团的邀请&#xff0c;华院计算技术&#xff08;上海&#xff09;股份有…

智能路由革命:AI 生态系统的智能高速交警

研究和行业基准测试揭露了一个惊人的事实&#xff1a;大多数企业的 AI 系统运行效率只有 15% 到 20%。罪魁祸首是谁呢&#xff1f;就是糟糕的查询路由。 想象一下这个现实情况&#xff1a; 你所在的组织每在 AI 上花 10 块钱&#xff0c;就有 8 块钱是浪费在把简单查询发送到…

[yolov11改进系列]基于yolov11引入倒置残差块块注意力机制iEMA的python源码+训练源码

【iEMA介绍】 iRMB&#xff08;Inverted Residual Mobile Block&#xff09;的框架原理&#xff0c;是一种结合轻量级CNN和注意力机制的方法&#xff0c;用于改进移动设备上的目标检测模型。IRMB通过倒置残差块和元移动块实现高效信息处理&#xff0c;同时保持模型轻量化。本文…

深度学习实战110-基于深度学习的工业系统故障诊断技术研究(卷积网络+注意力机制模型)

大家好,我是微学AI,今天给大家介绍一下深度学习实战110-基于深度学习的工业系统故障诊断技术研究(卷积网络+注意力机制模型)。工业系统故障诊断是确保现代工业设备安全稳定运行的关键技术环节。随着工业自动化和智能化水平的不断提高,传统故障诊断方法在应对日益复杂、多变…

Fluence (FLT) 2026愿景:RWA代币化加速布局AI算力市场

2025年5月29日&#xff0c;苏黎世 - Fluence&#xff0c;企业级去中心化计算平台&#xff0c;荣幸地揭开其2026愿景的面纱&#xff0c;并宣布将于6月1日起启动四大新举措。 Fluence 成功建立、推出并商业化了其去中心化物理基础设施计算网络&#xff08;DePIN&#xff09;&…

科学智能赋能空间科学研究(2):AI4S 范式下空间科学实验的核心挑战

中国科学院空间应用工程与技术中心在空间科学实验领域的研究覆盖了多模态空间科学实验数据模式挖掘、领域知识抽取、跨学科知识融合与认知智能等研究内容&#xff0c;有效促进了空间科学实验领域的数据应用生态的体系化建设&#xff0c;相关研究成果已正式发表于权威学术期刊《…

QML 无边框窗口翻转动画

目录 引言核心组件实现无边框翻转窗口&#xff08;FlipableDemo.qml&#xff09;登录页面和设置页面&#xff08;省略&#xff09;主界面集成&#xff08;Main.qml&#xff09; 下载链接 引言 接上篇 QML 滑动与翻转效果&#xff08;Flickable与Flipable&#xff09; 。本文通…