IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

标签:关联查询

共 1 篇相关文章

IT 累计浏览 3,871

复杂关联SQL的优化

这篇讲的是如何将一个耗时 750ms 的复杂关联 SQL 优化到毫秒级的过程。作者从一个真实案例出发,通过分析执行计划,精准定位了性能瓶颈:一条只返回一行数据的查询,却因为驱动表选择不当和索引缺失,导致在两张表上发生了全表扫描。 优化过程分为两步走。首先,针对 `left join` 的 d 表添加了缺失的 `yh_id` 索引,使其扫描行数从 5 万多行骤降至 272 行。但整体耗时并未改善,因为优化器仍坚持选择 a 表作为驱动表。作者进一步深入分析,发现根本原因在于关联字段 `yh_id` 在 b 表上没有索引,导致优化器认为以 a 表驱动的代价更低。于是,第二步是为 b 表和过滤性极强的 c 表分别添加了 `yh_id` 和 `yh_dm` 索引。 索引齐全后,优化器终于“回心转意”,转而选择数据量更小、过滤条件更强的 c 表作为驱动表,执行计划彻底改变,查询时间从 0.75 秒直接降为 0.00 秒。这个案例清晰地展示了,优化复杂 SQL 不能只看单表索引,更要理清表间关联逻辑与数据分布,通过分析执行计划来引导优化器做出正确选择。