类型 | 语法 | 特点 | 应用场景 |
---|---|---|---|
INNER JOIN | A JOIN B ON... |
只返回两表匹配的行 | 需要严格匹配数据的查询 |
LEFT JOIN | A LEFT JOIN B... |
保留左表全部数据,右表无匹配则为NULL | 统计时保留主表完整数据 |
RIGHT JOIN | A RIGHT JOIN B... |
保留右表全部数据,左表无匹配则为NULL | 较少使用(通常用LEFT JOIN替代) |
FULL JOIN | UNION实现 |
保留两表全部数据 | 需要合并两表所有记录的特殊场景 |
-- 基础关联查询
SELECT a.*, b.*
FROM 主表 a
JOIN 关联表 b ON a.id = b.foreign_key;
-- 带聚合的关联统计
SELECT
a.id,
a.name,
COUNT(b.id) AS item_count
FROM 主表 a
LEFT JOIN 子表 b ON a.id = b.parent_id
GROUP BY a.id;
-- 多表级联关联
SELECT a.name, b.value, c.status
FROM 表A a
JOIN 表B b ON a.id = b.a_id
JOIN 表C c ON b.id = c.b_id;
必加索引:关联字段必须建立索引
ALTER TABLE 子表 ADD INDEX idx_foreign_key (foreign_key);
查询精简原则:
SELECT *
,只查必要字段执行顺序:小表驱动大表(FROM后先写小表)
方案 | 优点 | 缺点 | 适用场景 |
---|---|---|---|
关联查询 | 数据实时准确,无冗余存储 | 复杂查询可能较慢 | 数据量小,变动频繁的场景 |
同步字段 | 查询性能极佳 | 需维护数据一致性 | 数据量大,统计查询频繁的场景 |