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 取决于你的业务需求:
以上就是如何在mysql中使用INNER JOIN和LEFT JOIN的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号