当前位置: 首页 > news >正文

JOIN 和 OUTER JOIN,SQL中常见的连接方式

1. INNER JOIN(简称 JOIN)

INNER JOIN 是 SQL 中最常用的一种连接方式,默认的 JOIN 就是 INNER JOIN。它返回两个表中满足连接条件的匹配记录。

  • 作用:返回两个表中所有满足 ON 条件的记录。
  • 特性:如果表中的某些行在连接条件下没有匹配的行,那么这些行将不会出现在结果集中。

例子

SELECT * FROM TableA JOIN TableB ON TableA.ID = TableB.ID;

这将只返回 TableATableBID 字段匹配的记录。

2. OUTER JOIN

OUTER JOIN 分为三种类型:LEFT OUTER JOINRIGHT OUTER JOINFULL OUTER JOIN,它们的主要特点是即使某些行在连接条件下没有匹配的行,仍然会出现在结果集里。

  • LEFT OUTER JOIN(左外连接):返回左表(即 JOIN 中左边的表)中的所有记录,即使右表中没有匹配的行。如果右表没有匹配的行,右表的列会显示 NULL

  • RIGHT OUTER JOIN(右外连接):返回右表(即 JOIN 中右边的表)中的所有记录,即使左表中没有匹配的行。如果左表没有匹配的行,左表的列会显示 NULL

  • FULL OUTER JOIN(全外连接):返回两个表中的所有记录。如果左表没有匹配的行,左表的列会显示 NULL;如果右表没有匹配的行,右表的列会显示 NULL

2.1 LEFT OUTER JOIN (左外连接)

LEFT OUTER JOIN 返回左表的所有记录以及右表中与之匹配的记录。如果右表中没有匹配的记录,则结果中相应的右表列会显示为 NULL

例子

SELECT * FROM TableA LEFT OUTER JOIN TableB ON TableA.ID = TableB.ID;

这将返回 TableA 中的所有记录,即使 TableB 中没有匹配的记录。如果 TableB 中没有与 TableA 中的某条记录匹配的行,TableB 中的字段将显示为 NULL

2.2 RIGHT OUTER JOIN (右外连接)

RIGHT OUTER JOIN 返回右表的所有记录以及左表中与之匹配的记录。如果左表中没有匹配的记录,则结果中相应的左表列会显示为 NULL

例子

SELECT * FROM TableA RIGHT OUTER JOIN TableB ON TableA.ID = TableB.ID;

这将返回 TableB 中的所有记录,即使 TableA 中没有匹配的记录。如果 TableA 中没有与 TableB 中的某条记录匹配的行,TableA 中的字段将显示为 NULL

2.3 FULL OUTER JOIN (全外连接)

FULL OUTER JOIN 返回左表和右表的所有记录。如果某一表中没有匹配的记录,则对应的字段将显示为 NULL

例子

SELECT * FROM TableA FULL OUTER JOIN TableB ON TableA.ID = TableB.ID;

这将返回 TableATableB 中的所有记录。如果某一表中的记录没有匹配,另一个表的列将显示为 NULL

3. 总结对比:

连接类型返回记录说明
INNER JOIN只有满足连接条件的匹配记录只有在两个表中都有匹配的记录才会被返回。
LEFT JOIN返回左表的所有记录,右表的匹配记录左表的所有记录都返回,右表没有匹配的会显示 NULL
RIGHT JOIN返回右表的所有记录,左表的匹配记录右表的所有记录都返回,左表没有匹配的会显示 NULL
FULL JOIN返回左右表的所有记录,左表和右表的匹配记录左右表所有记录都返回,没匹配的字段会显示 NULL

4. 使用场景

  • INNER JOIN:当你只关心两张表中有匹配记录的情况时,使用 INNER JOIN
  • LEFT JOIN:当你需要保留左表的所有记录,并且想知道左表记录是否在右表中有匹配时,使用 LEFT JOIN
  • RIGHT JOIN:当你需要保留右表的所有记录,并且想知道右表记录是否在左表中有匹配时,使用 RIGHT JOIN
  • FULL JOIN:当你需要保留两张表的所有记录时,使用 FULL JOIN,即使它们没有匹配的记录。
http://www.lryc.cn/news/516164.html

相关文章:

  • Vue2: table加载树形数据的踩坑记录
  • 电子信息硕士面试经验
  • dns网址和ip是一一对应的吗?
  • springboot3 redis 常用操作工具类
  • Java工程师实现视频文件上传minio文件系统存储及网页实现分批加载视频播放
  • Redis(二)value 的五种常见数据类型简述
  • Docker 环境中搭建 Redis 哨兵模式集群的步骤与问题解决
  • 【网页自动化】篡改猴入门教程
  • 【顶刊TPAMI 2025】多头编码(MHE)之极限分类 Part 4:MHE表示能力
  • Github - unexpected disconnect while reading sideband packet
  • Ubuntu 环境安装 之 RabbitMQ 快速入手
  • UE5中实现右键开镜效果
  • Apache HTTPD 换行解析漏洞(CVE-2017-15715)
  • Excel重新踩坑5:二级下拉列表制作;★数据透视表;
  • 力扣--35.搜索插入位置
  • C# 设计模式(行为型模式):模板方法模式
  • Leetcode打卡:设计一个ATM机器
  • 【TCP】SYN、ACK、FIN、RST、PSH、URG的全称
  • 【OceanBase】使用 Superset 连接 OceanBase 数据库并进行数据可视化分析
  • 【通识安全】应急救护常识23则
  • C语言:cJSON将struct结构体与JSON互相转换
  • 在Linux中,如何查看和修改网络接口配置?
  • 使用深度学习来实现图像超分辨率 综述!
  • 基于深度学习的视觉检测小项目(六) 项目的信号和变量的规划
  • 【Android项目学习】3. MVVMHabit
  • 在Linux中,如何配置负载均衡器以分配网络流量?
  • 手机投屏到电视的3种选择:无线本地投屏,无线远程投屏,AirPlay投屏
  • MySQL关联关系理论与实践
  • 多模态论文笔记——U-ViT(国内版DiT)
  • 在 IntelliJ IDEA 中开发 GPT 自动补全插件