图说 SQL 的 JOIN

JOIN 用于多表联查,分为:

  • OUTER JOIN

    • FULL OUTER JOIN

    • LEFT OUTER JOIN

    • RIGHT OUTER JOIN

  • INNER JOIN

OUTER 通常省略,所以我们在查询语句中看到的大都是 FULL JOIN、LEFT JOIN、RIGHT JOIN。

为了便于验证说明,下面我在 tempdb 数据库中创建两个表 TableA、TableB,两表的id 列为键列,并在两个表中分别插入4、3条数据:

可以看到id 的值2、5是TableA 独有的,而id=1是TableB仅有的;共有部分为id=3和id=4,如下图:

FULL JOIN=FULL OUTER JOIN

全连接,返回两个表全部数据,不存在的以NULL表示。

sql 复制代码
SELECT A.*,B.*
FROM dbo.TableA A
FULL JOIN dbo.TabeleB B 
  ON A.id=b.id

LEFT JOIN=LEFT OUTER JOIN

左连接,以左表为基准(本文中为表TableA),返回左表所有数据,右表不存在的数据以NULL补齐:

sql 复制代码
SELECT A.*,B.*
FROM dbo.TableA A
LEFT JOIN dbo.TabeleB B 
  ON A.id=b.id

我们可以通过左连接查询仅仅只存在于TableA中的数据,只需要在条件语句 WHERE 中加入 B.id IS NULL 即可:

sql 复制代码
SELECT A.*,B.*
FROM dbo.TableA A
LEFT JOIN dbo.TabeleB B 
  ON A.id=b.id
WHERE B.id IS NULL

RIGHT JOIN=RIGHT OUTER JOIN

右连接和左连接刚好相反,其以右表为基准(本例中以TableB为基表),返回右表所有数据,左表中不存在的数据以NULL补充:

sql 复制代码
SELECT A.*,B.*
FROM dbo.TableA A
RIGHT JOIN dbo.TabeleB B 
  ON A.id=b.id

这里我们可以在WHERE条件中增加 A.id IS NULL,以获取仅仅只有TableB 中存在的数据:

sql 复制代码
SELECT A.*,B.*
FROM dbo.TableA A
RIGHT JOIN dbo.TabeleB B 
  ON A.id=b.id
WHERE A.id IS NULL

INNER JOIN

外查询有三个,而内查询仅仅只有一个,返回的是两个表的公共部分:

sql 复制代码
SELECT A.*,B.*
FROM dbo.TableA A
INNER JOIN dbo.TabeleB B 
  ON A.id=b.id

内查询还有一个变形写法:

sql 复制代码
SELECT 
  A.*,B.*
FROM dbo.TableA A,dbo.TabeleB B
WHERE A.id=b.id

本文仅仅说明如何实现多表联查,如果想深入了解如何优化JOIN查询,可以参阅相关的文章:

SQL Server 数据 JOIN 基础

SQL Server 嵌套的循环联接(Nested Loops)

相关推荐
十叶知秋25 分钟前
【jmeter】jmeter的线程组功能的详细介绍
数据库·jmeter·性能测试
瓜牛_gn2 小时前
mysql特性
数据库·mysql
奶糖趣多多3 小时前
Redis知识点
数据库·redis·缓存
数新网络4 小时前
《深入浅出Apache Spark》系列②:Spark SQL原理精髓全解析
大数据·sql·spark
CoderIsArt4 小时前
Redis的三种模式:主从模式,哨兵与集群模式
数据库·redis·缓存
师太,答应老衲吧6 小时前
SQL实战训练之,力扣:2020. 无流量的帐户数(递归)
数据库·sql·leetcode
Channing Lewis7 小时前
salesforce case可以新建一个roll up 字段,统计出这个case下的email数量吗
数据库·salesforce
毕业设计制作和分享8 小时前
ssm《数据库系统原理》课程平台的设计与实现+vue
前端·数据库·vue.js·oracle·mybatis
ketil278 小时前
Redis - String 字符串
数据库·redis·缓存
NiNg_1_2348 小时前
高级 SQL 技巧详解
sql