当前位置: 首页 > news >正文

【MySQL】SQL 优化:关联查询优化


关联查询优化

在优化关联查询时,只有在被驱动表上建立索引才有效!

======= 🌟 青柠来相伴,代码更简单。🌟 =======
📚 本文所有内容,我都整理在了博客合集里。👇
🎯 搜索关注【青柠代码录】,即可查看所有博客文章 ~
======= 🌟 ================ 🌟 =======

1、left join

left join 时,左侧的为驱动表,右侧为被驱动表!

EXPLAIN SELECT * FROM class LEFT JOIN book ON class.card = book.card;

img

如何优化?在哪个表上建立索引?

ALTER TABLE book ADD INDEX idx_card( card);

img

删除 book 表的索引:drop index idx_card on book;

在 class 表上建立索引:alter table class add index idx_card(card);

img

2、inner join

如果是表关联的话,尽量使用inner join ,不要使用用left join | right join,如必须使用,一定要以小表为驱动

inner join 时,mysql会自己帮你把小结果集的表选为驱动表

内连接驱动表和被驱动表是由优化器决定的。优化器认为哪个成本比较小,就采用哪种作为驱动表。

  • 如果两张表只有一个有索引,那有索引的表作为被驱动表。原因:驱动表要全查出来。有没有索引你都得全查出来。
  • 两个索引都存在的情况下, 数据量大的 作为被驱动表(小表驱动大表)原因:驱动表要全部查出来,而大表可以通过索引加快查找

EXPLAIN SELECT * FROM book inner join class on class.card=book.card;

img

两个查询字段调换顺序,发现结果也是一样的!

img

在 book 表中,删除 9 条记录

img

straight_join: 效果和 inner join一样,但是会强制将左侧作为驱动表!

img

关联查询案例

结论:

  • 子查询尽量不要放在被驱动表,有可能使用不到索引;
  • left join时,尽量让实体表作为被驱动表。
  • 能够直接多表关联的尽量直接关联,不用子查询!
EXPLAIN SELECT ed.name '人物',c.name '掌门' 
FROM 
(SELECT e.name,d.ceo from t_emp e LEFT JOIN t_dept d on e.deptid=d.id) ed 
LEFT JOIN t_emp c on ed.ceo= c.id;

img

EXPLAIN 
SELECT e.name '人物',tmp.name '掌门' 
FROM t_emp e LEFT JOIN (SELECT d.id did,e.name FROM t_dept d LEFT JOIN t_emp e ON d.ceo=e.id)tmp 
ON e.deptId=tmp.did;

img

上述两个案例,第一个查询效率较高,且有优化的余地。

第二个案例中,子查询作为被驱动表,由于子查询是虚表, 无法建立索引,因此不能优化。

EXPLAIN SELECT e1.name '人物',e2.name '掌门' 
FROM t_emp e1 
LEFT JOIN t_dept d on e1.deptid = d.id 
LEFT JOIN t_emp e2 on d.ceo = e2.id ;

img

Explain SELECT e2.name '人物', 
(SELECT e1.name FROM t_emp e1 where e1.id= d.ceo) '掌门' 
from t_emp e2 LEFT JOIN t_dept d on e2.deptid=d.id;

img

---------------------------------

本文由mdnice多平台发布

http://www.jsqmd.com/news/523069/

相关文章:

  • CD32.【C++ Dev】类和对象(22) 内存管理(下)
  • 一天一个Python库:oauthlib - 轻松构建OAuth客户端和服务器
  • 2026年主数据管理厂家全面推荐,主流系统供应商怎么挑选 - 品牌2026
  • UART串口通信协议
  • 大学生HTML期末大作业——HTML+CSS+JavaScript购物商城(家具)
  • Vue中el-cascader多选级联选择器的终极指南:如何精准获取最后一级数据
  • GEO优化系统开发避坑指南:如何避免数据跨境传输的法律风险?
  • 2026年工业涂料推荐几家,口碑好的品牌有哪些 - 工业推荐榜
  • 选第一个Linux发行版前,必想的5个关键问题
  • 实验室超纯水机如何选:关键指标解读与国内外实力品牌对比分析 - 品牌推荐大师
  • Hanami Providers系统:掌握组件生命周期管理的10个最佳实践
  • 如何用Neorg构建合成生物学数据共享平台:终极架构设计指南
  • 20253906 2025-2026-2 《网络攻防实践》第1周作业
  • 终极iOS布局神器Stevia:告别Storyboard,代码布局效率提升10倍
  • 7.接口
  • 【异常】Maven私有仓库依赖解析失败排查指南 [ERROR] Failed to execute goal on project example-thirdparty-app:
  • 别再踩坑了!STM32F103ZET6上FreeRTOS 2024.06 LTS移植保姆级避坑指南
  • 2026年海湾园公墓服务商推荐:海湾园公墓、海湾园墓地、海湾园墓园、海湾园传统中式墓、海湾园双朝南墓、海湾园草坪葬服务商选择指南 - 海棠依旧大
  • 总结靠谱的磁控设备服务企业,华南地区好用的品牌 - 工业设备
  • 2026高端奢华腕表京表带更换全攻略|六城门店科普,含多品牌故障维修与数据解析 - 时光修表匠
  • 终极Superagent权限管理指南:API密钥与用户认证完整实现
  • 宏任务与微任务输出顺序练习题
  • Python数据分析新手必看:pandas一行代码计算平均值偏差的3种姿势
  • 2026杭州高端腕表鉴定真假指南|六城正规门店科普,含全品牌辨伪+维修攻略 - 时光修表匠
  • 2026年武汉旧房改造/武汉新房装修/武汉酒店装修/武汉整装装修品牌选购指南:武汉鑫同源建筑装饰工程有限公司 - 2026年企业推荐榜
  • 高难度电子半导体行业厂房环保工程如何落地?优质厂房环保工程公司具备哪些核心资质 - 品牌2026
  • 文墨共鸣大模型C语言入门教学:代码解释与调试助手
  • 从零搭建私有知识库问答系统:Spring AI + Milvus + 智谱GLM-5实战教程
  • OBS项目架构分析:理解大型C++多媒体应用的设计模式
  • 网络分析仪怎么挑?靠谱售后+高性价比厂家一网打尽! - 品牌推荐大师