【MySQL】驱动表、被驱动表详解。—— 性能优化。

文章目录

我是一名立志把细节都说清楚的博主,欢迎【关注】🎉 ~

原创不易, 如果有帮助 ,记得【点赞】【收藏】 哦~ ❥(^_-)~

如有错误、疑惑,欢迎【评论】指正探讨,我会尽可能第一时间回复的,谢谢支持


什么是 驱动表 和 被驱动表?

在2个表或2个以上表的连接查询中(多数涉及关键字 JOIN ),才会涉及 驱动表被驱动表

在使用多表嵌套连接时,首先,会全表扫描该一个表作为查询条件,这个表叫做 驱动表 。然后用驱动表返回的结果集逐行去匹配的表,叫做 被驱动表


哪个表是驱动表?

  • 驱动表是由 MySQL 优化器选择的
  • 我们只能通过理解优化器的选择倾向,让某个表更接近优化器的选择标准,让这个表尽可能的成为驱动表。

优化器选择驱动表的原则是:让查询的性能更好。 基于这个原则,可以从以下几个方面考虑:

  • 小表优先: 因为驱动表会被全表扫描,所以优先选择小表作为驱动表。全表扫描的效率更高。
  • 有where条件的优先: 优化器优先选择有过滤条件的表作为驱动表,能够减少部分匹配操作。
  • 连接类型:
    • LEFT JOIN / LEFT OUTER JOIN:这两个关键字会返回左表中的所有的记录(符合驱动表全表扫描的特性),而右表的匹配记录是可选的。所以会优先选择左表为驱动表。
    • RIGHT JOIN / RIGHT OUTER JOIN:优先选择右表作为驱动表,原理同上。
    • INNER JOIN:优化器会评估执行计划中表的扫描次数,需要扫描次数更少的表优先作为驱动表。

性能优化建议:

我们应该有意识的调整驱动表更符合MySQL 优化器的选择标准。

  • 尽可能使用小表作为驱动表。驱动表因为要被全表扫描,所以我们在选择上,我们应该尽量选择小表作为驱动表(至少是相对小表)。
  • 更具需要增加筛选条件,减少部分匹配操作。
  • 根据连接类型的特点调整驱动表的位置。 让驱动表符合不同连接查询选择驱动表的倾向。
  • 被驱动表使用索引。 被驱动的表通常是大表,对于大表,我们可以使用索引优化查询效率。

我是一名立志把细节都说清楚的博主,欢迎【关注】🎉 ~

原创不易, 如果有帮助 ,记得【点赞】【收藏】 哦~ ❥(^_-)~

如有错误、疑惑 ,欢迎【评论】指正探讨,我会尽可能第一时间回复的,谢谢支持

相关推荐
Alice-YUE3 小时前
前端性能优化完全指南:从指标到实战
前端·学习·性能优化
薛定谔的悦3 小时前
共享数据总线(DPR)设计模式——嵌入式系统的“内存数据库”
jvm·数据库·设计模式
程序猿online3 小时前
本地mysql密码重置
数据库·mysql
四维迁跃3 小时前
如何排查SQL存储过程死锁_分析死锁日志与索引优化
jvm·数据库·python
m0_741173333 小时前
如何检测SQL注入风险_利用模糊测试技术发现漏洞
jvm·数据库·python
2401_846339564 小时前
CSS如何解决Less与CSS兼容性问题_通过配置文件实现平滑过渡与混合开发
jvm·数据库·python
qq_413847404 小时前
CSS如何控制全屏显示的元素样式
jvm·数据库·python
云动课堂4 小时前
【运维实战】MySQL 8.0 数据库 · 一键自动化部署方案 (适配银河麒麟 V10 / 龙蜥 8 / Rocky Linux 8 / CentOS 8)
linux·运维·数据库
阿正呀4 小时前
CSS粘性定位不生效怎么办_检查父元素高度与overflow属性设置
jvm·数据库·python
2403_883261094 小时前
如何获取DDL语句_DBMS_METADATA.GET_DDL提取对象定义
jvm·数据库·python