

新闻资讯
技术学院INNER JOIN只返回两表匹配的行,如查询有订单的用户;LEFT JOIN返回左表全部记录,无匹配时右表字段为NULL,如列出所有用户及其订单(含未下单者)。
在 MySQL 中,INNER JOIN 和 LEFT 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 会返回左表(即 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 取决于你的业务需求: