2026-05/04~10技术问题处理

2026-05/04~10技术问题处理

  • [一.LEFT JOIN 与 INNER JOIN](#一.LEFT JOIN 与 INNER JOIN)
    • [1. 原始业务场景](#1. 原始业务场景)
    • [2. 原有错误 SQL](#2. 原有错误 SQL)
    • [3. 存在问题 & 根因](#3. 存在问题 & 根因)
    • [4. 分步优化 & 每步原因](#4. 分步优化 & 每步原因)
    • [5. 最终正确 SQL](#5. 最终正确 SQL)
    • [6. 配套索引](#6. 配套索引)
    • [7. 二次拓展](#7. 二次拓展)

一.LEFT JOIN 与 INNER JOIN

1. 原始业务场景

左连接:以左表为主表,保留主表所有数据,根据连接条件匹配右表数据,匹配成功直接回显,匹配失败即为null.

内连接: 保留符合连接条件的数据。

2. 原有错误 SQL

sql 复制代码
SELECT COUNT(task.id) FROM pro_inspect_await_instance_task task LEFT JOIN pro_inspect_product_submit submit 
ON task.product_submit_id = submit.id  WHERE submit.status <= 10

3. 存在问题 & 根因

  1. 逻辑错误:LEFT JOIN 左连接后,WHERE submit.status <=10 会把 submit为NULL 的数据全部过滤,左连接变相变成内连接,等价于内连接;
  2. 计数冗余:COUNT(task.id) 主键非空,和 COUNT() 效果一致,但优化器对 COUNT() 优化更好;
  3. 无索引:关联字段、过滤字段无索引,大表全表扫描性能差。

4. 分步优化 & 每步原因

  1. 把 submit 过滤条件从 WHERE 移到 JOIN 的 ON 后面
    原因:ON 后过滤只过滤关联匹配的数据,不会删掉主表 task 不匹配的数据,保留左连接语义;
  2. COUNT(task.id) 改为 COUNT(*)
    原因:主键非空,语义等价,数据库优化器处理更高效;
  3. 给关联字段、状态字段建立联合索引
    原因:避免全表扫描,走索引快速过滤 + 关联。

5. 最终正确 SQL

sql 复制代码
-- 保留主表所有数据,仅关联内过滤状态
SELECT COUNT(*) FROM pro_inspect_await_instance_task task LEFT JOIN pro_inspect_product_submit submit 
ON task.product_submit_id = submit.id  AND submit.status <= 10; -- 条件放ON里

6. 配套索引

sql 复制代码
CREATE INDEX idx_submit_status_id ON pro_inspect_product_submit(status, id);
CREATE INDEX idx_task_submit_id ON pro_inspect_await_instance_task(product_submit_id);

7. 二次拓展

若业务本来就只需要两表都匹配数据,直接改用 INNER JOIN 更直观;大表可改用 EXISTS 半连接优化。

相关推荐
倔强的石头_6 小时前
《Kingbase护城河》——猎捕慢查询:执行计划的微观解析与索引调优实战
数据库
SelectDB8 小时前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑
大数据·数据库·python
Flittly9 小时前
【AgentScope Java新手村系列】(16)从RAG到多路检索
java·spring boot·spring
小兔崽子去哪了9 小时前
Java 生成二维码解决方案
java·后端
人活一口气14 小时前
从JVM调优到MCP协议:Java全栈技术体系深度总结与企业级架构实践
java·spring boot
NE_STOP16 小时前
Vibe Coding -- 完整项目案例实操
java
荣码16 小时前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python
SimonKing16 小时前
Google第三方授权登录
java·后端·程序员
明月光81816 小时前
从一行 @Builder 说起:重新拾起 Java 的 Lombok、注解与 Builder 模式
java
考虑考虑1 天前
Mybatis实现批量插入
java·后端·mybatis