内连接,左连接,右连接怎么区别开来?

区分这三种连接其实非常简单,核心就在于看**"谁的数据必须全部保留,谁的数据没有匹配就要被过滤掉"**。

为了让你彻底搞懂,我们可以把 user 表(用户)和 orders 表(订单)想象成两个班级,它们通过 user_id 这个学号来互相找朋友。

📌 内连接 (INNER JOIN):只留"双向奔赴"的

  • 核心逻辑取交集。只有当两张表能完美匹配上时,数据才会被保留。
  • 业务场景:查"哪些用户下过单"。
  • 结果表现:如果一个用户没下过单,或者一个订单找不到对应的用户,这两条数据都会被直接扔掉。
  • 口诀两边都有才算数。

📌 左连接 (LEFT JOIN):保住"左边老大"的全部

  • 核心逻辑保左表 。以 FROM 后面的左表为主,不管右表有没有匹配,左表的数据必须全部显示。如果右表没匹配上,就用 NULL(空值)来填充。
  • 业务场景:查"所有用户的下单情况"(哪怕他没买过东西,也要把他的名字列出来)。
  • 结果表现 :所有用户都会出现。张三下了两单就显示两行;李四没下单,他的订单字段就显示为 NULL
  • 口诀左边全都要,右边随缘配。

📌 右连接 (RIGHT JOIN):保住"右边小弟"的全部

  • 核心逻辑保右表 。跟左连接完全相反,以 JOIN 后面的右表为主,不管左表有没有匹配,右表的数据必须全部显示。左表没匹配上就填 NULL
  • 业务场景:查"所有订单的归属人"(哪怕系统里有找不到主人的异常脏数据订单,也要把它列出来)。
  • 结果表现 :所有订单都会出现。正常订单能匹配到用户名;异常订单的用户名字段显示为 NULL
  • 口诀右边全都要,左边随缘配。

为了让你一眼看懂,我们用一张表格来总结它们的区别(假设左表是用户,右表是订单):

连接类型 核心作用 没匹配上的数据怎么办? 实际开发常用度
INNER JOIN 只要两者都有的(交集) 直接丢弃,不出现在结果里 ⭐⭐⭐⭐⭐ (查精准关联数据)
LEFT JOIN 保住左表所有,顺带查右表 左表保留,右表对应字段填 NULL ⭐⭐⭐⭐⭐ (最常用,符合阅读习惯)
RIGHT JOIN 保住右表所有,顺带查左表 右表保留,左表对应字段填 NULL ⭐ (极少用,通常会被改写成左连接)

💡 给你一个万能记忆法

在实际写 SQL 时,你只需要记住两点:

  1. 忘掉 RIGHT JOIN :因为 A RIGHT JOIN B 等价于 B LEFT JOIN A。只要你习惯把想保全的主表写在左边,永远只用 LEFT JOIN 就能解决 99% 的外连接需求。
  2. 看 ON 后面的条件INNER JOIN 是严格的"门当户对",而 LEFT/RIGHT JOIN 则是"偏心"地保护某一边的数据完整性。
相关推荐
kishu_iOS&AI6 分钟前
LLM —— Milvmus向量数据库
数据库·人工智能·milvus
名不经传的养虾人10 分钟前
从0到1:企业级AI项目迭代日记 Vol.46|三个检索源、缓存限流、深度整合——联网检索一日冲刺
数据库·人工智能·agent·ai编程·ai工作流·企业ai
BugShare17 分钟前
Mac 上原生开发的开源免费、尽享丝滑数据库工具
数据库·macos·开源
Java爱好狂.17 分钟前
阿里1658页2026最新Java面试题总结(含答案)
数据库·redis·程序员·java面试·java面试题·java编程·java八股文
jieyucx31 分钟前
《Go 数据库编程开篇:彻底打通 database/sql 与 MySQL 驱动的连接池调优密码》
数据库·sql·golang
白露与泡影35 分钟前
深入理解MySQL事务隔离级别:MVCC机制与Next-Key Lock如何解决幻读问题?
数据库·mysql
Gong-Yu35 分钟前
MySQL数据库运维——性能优化进阶2️⃣
运维·数据库·mysql·性能优化
吴声子夜歌38 分钟前
SQL经典实例——概述
数据库·sql
布朗克16840 分钟前
40 Redis与微服务入门
java·数据库·redis·微服务