0

0

mysql中多表连接的索引优化与查询效率

P粉602998670

P粉602998670

发布时间:2026-02-15 10:32:52

|

849人浏览过

|

来源于php中文网

原创

join字段必须有索引,否则触发全表扫描;索引须建在on子句列上,复合索引注意顺序;小结果集应作驱动表;避免join条件中使用函数。

mysql中多表连接的索引优化与查询效率

JOIN 字段必须有索引,否则就是全表扫描

MySQL 在执行 INNER JOINLEFT JOIN 时,如果连接条件(如 ON t1.user_id = t2.user_id)中任意一侧字段没索引,优化器大概率放弃使用索引,转为嵌套循环 + 全表扫描。尤其当被驱动表(右表)数据量大时,性能断崖式下降。

  • 检查方式:
    EXPLAIN SELECT ... JOIN ...
    中看 type 是否为 ALLindexkey 列是否为 NULL
  • 索引要建在 ON 子句实际参与比较的列上,不是 WHERE 里的列 —— 即使 WHERE 条件更“关键”,没在 ON 里用,对 JOIN 效率无直接帮助
  • 复合索引需注意顺序:若写 ON a.x = b.x AND a.y = b.y,则 b(x,y) 索引有效,b(y,x) 通常无效(除非 y 是常量)

驱动表选择影响巨大,小结果集应作驱动表

MySQL 的 JOIN 是单向嵌套循环:先取驱动表(左表)一行,再根据 ON 条件去被驱动表(右表)查匹配行。所以驱动表越小,外层循环次数越少,整体 I/O 和 CPU 开销越低。

依图语音开放平台
依图语音开放平台

依图语音开放平台

下载
  • 优化器一般能自动选,但复杂查询(含子查询、函数、OR 条件)可能误判;可用 STRAIGHT_JOIN 强制指定驱动表顺序
  • 避免在驱动表上用 SELECT * 或大字段(如 TEXT),减少内存拷贝和网络传输开销
  • 如果 LEFT JOIN 的左表加了 WHERE 过滤但没走索引,可能导致实际驱动表变大——先确认 WHERE 是否命中索引,再谈 JOIN 顺序

避免在 JOIN 条件中使用函数或表达式

一旦在 ONUSING 中对字段做运算,比如 ON DATE(t1.created_at) = DATE(t2.date),该字段就无法使用索引 —— MySQL 无法将函数结果与索引 B+ 树结构对齐。

  • 正确做法是预计算或改写逻辑:例如把日期范围下推到 WHERE,用 t1.created_at >= '2024-01-01' AND t1.created_at 替代 <code>DATE()
  • 同理,ON UPPER(t1.name) = UPPER(t2.name) 会失效;若业务允许,统一存小写并建函数索引(MySQL 8.0+ 支持 CREATE INDEX idx_name ON t1 ((LOWER(name)))
  • 隐式类型转换也危险:ON t1.id = t2.user_id 中若 t1.idINTt2.user_idVARCHAR,MySQL 会把后者全转成数字比对,索引失效

覆盖索引 + 延迟关联可大幅减少回表

当 JOIN 后还要查大量非索引字段(如 SELECT t1.*, t2.content),MySQL 不得不反复回主键索引捞数据,I/O 成倍增加。覆盖索引本身不能跨表,但可通过“延迟关联”模式规避。

  • 典型写法:
    SELECT t1.*, t2.content FROM t1 INNER JOIN (SELECT id FROM t2 WHERE status=1) AS t2_ids ON t1.t2_id = t2_ids.id INNER JOIN t2 ON t2.id = t2_ids.id
    —— 先用最小结果集驱动,再补全字段
  • 确保子查询 (SELECT id FROM t2 WHERE ...) 能走索引(哪怕只是 status 单列索引),且返回行数可控
  • 如果业务允许,尽量让 SELECT 只取必要字段,配合联合索引把常用查询字段都包含进去(如 INDEX idx_cover (a,b,c) 支持 SELECT a,b WHERE a=? AND b=?
真正卡住性能的,往往不是 JOIN 本身,而是连接字段缺失索引、驱动表意外膨胀、或者一个看似无害的函数调用悄悄让整个索引失效。这些点不查 EXPLAIN 几乎发现不了。

热门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的相关下载、相关课程等内容,供大家免费下载使用。

677

2023.06.20

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

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

371

2023.06.21

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

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

284

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中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

262

2023.07.25

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

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

392

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

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

537

2023.08.11

mysql忘记密码
mysql忘记密码

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

636

2023.08.14

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

145

2026.02.13

热门下载

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

精品课程

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

共48课时 | 2.2万人学习

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

共3课时 | 0.3万人学习

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

共1课时 | 833人学习

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

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