0

0

mysql数据库的查询优化器与执行计划分析

P粉602998670

P粉602998670

发布时间:2026-02-28 09:41:03

|

188人浏览过

|

来源于php中文网

原创

mysql执行计划用explain查看,关键看type、key、rows和extra;order by不走索引因不满足最左前缀、排序方向一致或范围条件中断;联合索引需按查询模式设计顺序;选错索引可强制指定、更新统计信息或排查隐式转换。

mysql数据库的查询优化器与执行计划分析

怎么看 MySQL 的执行计划(EXPLAIN)

直接在 SELECT 语句前加 EXPLAIN,就能看到优化器打算怎么执行这条查询。它不真正运行查询,只返回执行计划的元信息。

关键字段要盯紧:type(访问类型)、key(实际用的索引)、rows(预估扫描行数)、Extra(额外操作,比如 Using filesortUsing temporary)。

示例:

EXPLAIN SELECT * FROM orders WHERE user_id = 123 AND status = 'paid';
  • typerefrange 好,range 又比 ALL(全表扫描)好
  • key 为空说明没走索引,得查原因:是不是索引失效?字段类型隐式转换?函数包裹了索引列?
  • rows 如果远大于实际结果集,往往意味着索引选择不当或统计信息过期,可运行 ANALYZE TABLE orders;

为什么 ORDER BY 有时不走索引

MySQL 只有在满足“索引最左前缀 + 排序方向一致 + 无范围条件中断”的前提下,才能利用索引完成排序。一旦破坏任一条件,就会触发 Using filesort

常见断点场景:

  • WHERE 中用了范围查询(如 created_at > '2024-01-01'),后面跟的 ORDER BY id 就无法复用联合索引中的 id
  • ORDER BY a ASC, b DESC —— 多数版本不支持混合排序方向走索引(8.0.12+ 开始部分支持,但需显式定义降序索引)
  • SELECT * + ORDER BY indexed_col,但 WHERE 条件没覆盖该索引的最左列

验证方式:看 EXPLAIN 输出中 Extra 是否含 Using filesort;若存在,优先考虑调整索引顺序或拆分查询逻辑。

MvMmall 网店系统
MvMmall 网店系统

免费的开源程序长期以来,为中国的网上交易提供免费开源的网上商店系统一直是我们的初衷和努力奋斗的目标,希望大家一起把MvMmall网上商店系统的免费开源进行到底。2高效的执行效率由资深的开发团队设计,从系统架构,数据库优化,配以通过W3C验证的面页模板,全面提升页面显示速度和提高程序负载能力。3灵活的模板系统MvMmall网店系统程序代码与网页界面分离,灵活的模板方案,完全自定义模板,官方提供免费模

下载

联合索引怎么建才不被“浪费”

联合索引不是字段简单堆砌,顺序决定它能覆盖哪些查询模式。优化器只会按索引定义的从左到右顺序匹配 WHERE 条件和 ORDER BY

建索引前先问三个问题:

  • 哪些字段最常出现在 WHERE 等值条件中?放最左
  • 是否有范围查询(>, BETWEEN, LIKE 'abc%')?它右边的字段就无法用于索引查找
  • 是否需要避免 filesort?把 ORDER BY 字段尽可能放在范围条件之后、索引末尾

例如,高频查询是:WHERE category = ? AND status IN (?, ?) ORDER BY created_at DESC,那么 (category, status, created_at) 是合理顺序;而 (status, category, created_at) 就会导致 category = ? 无法使用索引前缀。

查询优化器“选错索引”怎么办

优化器依赖表统计信息做成本估算,但数据分布倾斜、长期未更新统计、或复杂表达式都可能导致它误判。典型表现是明明有索引却走了全表扫描,或选了低效的索引。

可干预手段有限但实用:

  • 强制指定索引:SELECT * FROM t USE INDEX (idx_user_status) WHERE ...(慎用,后续数据增长可能让该索引再次变差)
  • 更新统计信息:ANALYZE TABLE t;,尤其在大批量导入/删除后
  • 检查是否因隐式类型转换导致索引失效:比如 user_idINT,但传入字符串 '123',会触发全字段转类型,索引失效
  • SHOW WARNINGS 查看优化器重写后的语句,有时能发现意外的子查询展开或条件合并

真正棘手的是优化器在多个“看起来差不多”的索引间摇摆——这时候往往不是调优问题,而是数据模型或查询结构本身需要收敛,比如把大表关联拆成应用层分步查,或引入冗余排序字段减少动态计算。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

682

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

432

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

286

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

519

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

264

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

392

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

539

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

640

2023.08.14

Golang 并发编程模型与工程实践:从语言特性到系统性能
Golang 并发编程模型与工程实践:从语言特性到系统性能

本专题系统讲解 Golang 并发编程模型,从语言级特性出发,深入理解 goroutine、channel 与调度机制。结合工程实践,分析并发设计模式、性能瓶颈与资源控制策略,帮助将并发能力有效转化为稳定、可扩展的系统性能优势。

11

2026.02.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.4万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 838人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号