0

0

php查询慢怎么优化_索引与sql语句调整技巧【详解】

看不見的法師

看不見的法師

发布时间:2026-03-02 19:09:14

|

865人浏览过

|

来源于php中文网

原创

加索引仍慢的主因是回表、filesort、临时表、索引失效或数据量过大;需结合explain format=json分析rows、filtered和extra,优化联合索引顺序与覆盖度,并删减低效索引。

php查询慢怎么优化_索引与sql语句调整技巧【详解】

为什么加了索引,EXPLAIN 显示用了,但查询还是慢?

常见错觉:只要 EXPLAINtyperefrange,就代表快。实际可能卡在回表、排序、临时表或数据量膨胀上。

  • 如果 SELECT * 且索引不覆盖查询字段,InnoDB 会根据主键回表查完整行——10万行 = 10万次随机磁盘 I/O
  • ORDER BY 字段没包含在联合索引最右位置,或用了 filesort,大数据量时直接拖垮
  • 索引列上有函数或隐式转换,比如 WHERE YEAR(created_at) = 2024,索引失效
  • LIKE '%abc' 开头,B+ 树无法利用索引做范围扫描

实操建议:先跑 EXPLAIN FORMAT=JSON,重点看 rows(预估扫描行数)、filtered(过滤率)、Extra 里有没有 Using filesortUsing temporary

WHERE 条件顺序和联合索引字段顺序到底谁重要?

MySQL 不关心 WHERE 子句里条件写的先后,只认联合索引的定义顺序。但人容易写反,导致索引“部分失效”。

  • 建了 INDEX (user_id, status, created_at),那么 WHERE user_id = ? AND status = ? 能用,但 WHERE status = ? AND created_at > ? 完全用不上
  • 等值条件(=)必须放最左,范围条件(>, BETWEEN)后面字段无法走索引——WHERE a = 1 AND b > 2 AND c = 3 中,c 就不会被索引命中
  • 区分度高的字段往前放,比如 user_id(百万级唯一值)比 status(通常就 3–5 个枚举值)更适合放索引首位

示例:查“某用户最近 10 条待处理订单”,别建 (status, created_at, user_id),而应建 (user_id, status, created_at),再配合 ORDER BY created_at DESC LIMIT 10

立即学习PHP免费学习笔记(深入)”;

Hotpot AI Background Remover
Hotpot AI Background Remover

Hotpot.ai推出的图片背景移除工具

下载

PHP 层怎么避免“一次查全,PHP 循环过滤”这种低效操作?

典型场景:SQL 查出 5000 行,PHP 用 foreach 遍历,再用 if ($row['status'] !== 'done') 筛一遍。本质是把数据库该干的事甩给了 PHP。

  • 数据库筛选永远比 PHP 内存遍历快——尤其涉及字符串比较、时间计算、关联字段判断时
  • 不要在 PHP 里拼 IN 列表超过 1000 项,改用临时表或分批查;更别用 array_filter() 替代 WHERE
  • 注意 PDO 默认是 PDO::FETCH_BOTH,取 10 万行会多占一倍内存,明确设为 PDO::FETCH_ASSOC
  • 大结果集别用 fetchAll() 一次性加载,改用 fetch() 迭代,或游标式查询(MYSQLI_USE_RESULT

错误写法:$rows = $pdo->query("SELECT * FROM orders")->fetchAll(); foreach ($rows as $r) { if ($r['amount'] > 1000) {...} } → 应该让 SQL 做掉 WHERE amount > 1000

什么时候该删索引,而不是加索引?

索引不是越多越好。写多读少的表,或长期不用的索引,反而拖慢 INSERT/UPDATE/DELETE,还吃内存和磁盘空间。

  • SELECT * FROM sys.schema_unused_indexes(MySQL 8.0+)或 performance_schema.table_io_waits_summary_by_index_usage 找“零命中”索引
  • 单表索引总数建议控制在 5–7 个以内;超过这个数,每增一个都要问:这个查询频次够不够高?有没有更优的联合索引能覆盖它?
  • UNIQUE 索引在业务无强唯一性要求时,慎用——唯一性校验有开销,且一旦插入冲突,应用层处理比普通索引失败更重
  • 监控 Innodb_buffer_pool_readsInnodb_buffer_pool_read_requests 比值,若长期 > 1%,说明索引/数据太大,Buffer Pool 装不下,得考虑归档旧数据而非硬加索引

真正卡点往往不在“怎么加”,而在“哪些可以砍”。上线前跑一周慢查日志,按 Query_timeRows_examined 排序,优先优化那几个“高频 + 高扫描”的 SQL,而不是给所有 WHERE 都配索引。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1068

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

339

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

379

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1967

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

379

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1519

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

438

2024.04.29

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

48

2026.02.28

热门下载

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

精品课程

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

共137课时 | 12.8万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

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

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