INNER JOIN只返回两表匹配的行,如查询有订单的用户;LEFT JOIN返回左表全部记录,无匹配时右表字段为NULL,如列出所有用户及其订单(含未下单者)。

在 MySQL 中,INNER JOIN 和 LEFT JOIN 是用来从多个表中查询数据的常用连接方式。它们的核心区别在于如何处理不匹配的数据。
INNER JOIN:只返回两表匹配的行
当你使用 INNER JOIN 时,MySQL 只会返回两个表中“连接条件”成立的记录。如果某条记录在任一表中没有对应匹配项,它将被排除。
语法格式:
SELECT 列名 FROM 表1 INNER JOIN 表2 ON 表1.列 = 表2.列;
示例场景:有两个表:users(用户信息)和 orders(订单信息)。你想查出“有下单记录的用户”及其订单详情。
SELECT users.name, orders.order_id, orders.amount FROM users INNER JOIN orders ON users.id = orders.user_id;
这条语句只会返回那些在 orders 表中有对应 user_id 的用户数据。没有下过单的用户不会出现在结果中。
LEFT JOIN(或 LEFT OUTER JOIN):返回左表全部记录
LEFT JOIN 会返回左表(即 FROM 后的表)的所有记录,即使右表中没有匹配项。如果右表无对应数据,相关字段值为 NULL。
语法格式:
SELECT 列名 FROM 表1 LEFT JOIN 表2 ON 表1.列 = 表2.列;
示例场景:你想列出所有用户,包括他们是否下过单。没下过单的用户,订单信息显示为 NULL。
SELECT users.name, orders.order_id, orders.amount FROM users LEFT JOIN orders ON users.id = orders.user_id;
此时,即使某个用户没有订单,也会出现在结果中,order_id 和 amount 字段为 NULL。
使用建议与注意事项
选择哪种 JOIN 取决于你的业务需求:
- 需要“交集”数据时用 INNER JOIN —— 比如统计已成交订单的客户。
- 需要“主表完整 + 关联表补充”时用 LEFT JOIN —— 比如查看所有注册用户,不论是否消费。
- 连接条件(ON 后面的表达式)要准确,通常基于外键关系。
- LEFT JOIN 的性能可能略低于 INNER JOIN,尤其在大数据量时,注意索引优化。
- 可以在 LEFT JOIN 结果上加 WHERE 条件过滤 NULL 值,实现“只查无订单用户”等逻辑。










