数据库左连接、右连接、内连接、全连接笔记

原英文文章链接:https://www.codeproject.com/Articles/33052/Visual-Representation-of-SQL-Joins 
准备 
表A:

-- auto-generated definition
CREATE TABLE table_a
(
  PK    INT(10)     NOT NULL
    PRIMARY KEY,
  Value VARCHAR(25) NULL
)
  COMMENT '表A';
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

表B:

-- auto-generated definition
CREATE TABLE table_b
(
  PK    INT(10)     NOT NULL
    PRIMARY KEY,
  Value VARCHAR(50) NULL
)
  COMMENT '表B';
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

表A数据: 
数据库左连接、右连接、内连接、全连接笔记_第1张图片 
表B数据: 
数据库左连接、右连接、内连接、全连接笔记_第2张图片

下面是各种连接的韦恩图: 
数据库左连接、右连接、内连接、全连接笔记_第3张图片 
详细分析 
1.INNER JOIN (内连接) 
内连接是一种一一映射关系,就是两张表都有的才能显示出来 
用韦恩图表示是两个集合的交集,如图: 
数据库左连接、右连接、内连接、全连接笔记_第4张图片 
实现代码:

SELECT  A.PK AS A_PK,A.Value AS A_Value,B.PK AS B_PK,B.Value AS B_Value
FROM table_a A
INNER JOIN table_b B
ON A.PK = B.PK;
  • 1
  • 2
  • 3
  • 4

查询结果: 
数据库左连接、右连接、内连接、全连接笔记_第5张图片 
2.LEFT JOIN (左连接) 
左连接是左边表的所有数据都有显示出来,右边的表数据只显示共同有的那部分,没有对应的部分只能补空显示,所谓的左边表其实就是指放在left join的左边的表 
用韦恩图表示如下: 
数据库左连接、右连接、内连接、全连接笔记_第6张图片 
实现代码:

SELECT  A.PK AS A_PK,A.Value AS A_Value,B.PK AS B_PK,B.Value AS B_Value
FROM table_a A
LEFT JOIN  table_b B
ON A.PK = B.PK;
  • 1
  • 2
  • 3
  • 4

查询结果: 
数据库左连接、右连接、内连接、全连接笔记_第7张图片

3.RIGHT JOIN(右连接) 
右连接正好是和左连接相反的,这里的右边也是相对right join来说的,在这个右边的表就是右表 
用韦恩图表示如下: 
数据库左连接、右连接、内连接、全连接笔记_第8张图片 
实现代码:

SELECT  A.PK AS A_PK,A.Value AS A_Value,B.PK AS B_PK,B.Value AS B_Value
FROM table_a A
RIGHT JOIN   table_b B
ON A.PK = B.PK;
  • 1
  • 2
  • 3
  • 4

查询结果: 
数据库左连接、右连接、内连接、全连接笔记_第9张图片

4.OUTER JOIN(外连接、全连接) 
查询出左表和右表所有数据,但是去除两表的重复数据 
韦恩图表示如下: 
数据库左连接、右连接、内连接、全连接笔记_第10张图片 
实现代码:

SELECT  A.PK AS A_PK,A.Value AS A_Value,B.PK AS B_PK,B.Value AS B_Value
FROM table_a A
FULL  JOIN table_b B
ON A.PK = B.PK;
  • 1
  • 2
  • 3
  • 4

上面代码在mysql执行是报错的,因为mysql不支持全连接,只能用以下代码实现效果,含义是左连接+右连接+去重=全连接:

SELECT  A.PK AS A_PK,A.Value AS A_Value,B.PK AS B_PK,B.Value AS B_Value
FROM table_a A
LEFT JOIN  table_b B
ON A.PK = B.PK
 UNION
SELECT  A.PK AS A_PK,A.Value AS A_Value,B.PK AS B_PK,B.Value AS B_Value
FROM table_a A
RIGHT JOIN  table_b B
ON A.PK = B.PK;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

查询结果: 
数据库左连接、右连接、内连接、全连接笔记_第11张图片

5.LEFT JOIN EXCLUDING INNER JOIN(左连接不包含内连接) 
这个查询是只查询左边表有的数据,共同有的也不查出来 
韦恩图表示如下: 
数据库左连接、右连接、内连接、全连接笔记_第12张图片 
实现代码:

SELECT A.PK AS A_PK, A.Value AS A_Value,
B.Value AS B_Value, B.PK AS B_PK
FROM Table_A A
LEFT JOIN Table_B B
ON A.PK = B.PK
WHERE B.PK IS NULL
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

查询结果: 
这里写图片描述 
6.RIGHT JOIN EXCLUDING INNER JOIN(右连接不包含内连接) 
这个查询是只查询右边表有的数据,共同有的也不查出来 
韦恩图表示如下: 
数据库左连接、右连接、内连接、全连接笔记_第13张图片 
实现代码:

SELECT A.PK AS A_PK, A.Value AS A_Value, B.PK AS B_PK,
B.Value AS B_Value
FROM Table_A A
RIGHT JOIN Table_B B
ON A.PK = B.PK
WHERE A.PK IS NULL
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

查询结果: 
这里写图片描述 
7.OUTER JOIN EXCLUDING INNER JOIN(外连接不包含内连接) 
意思就是查询左右表各自拥有的那部分数据 
韦恩图表示如下: 
数据库左连接、右连接、内连接、全连接笔记_第14张图片 
实现代码:

SELECT A.PK AS A_PK, A.Value AS A_Value,
B.Value AS B_Value, B.PK AS B_PK
FROM Table_A A
FULL OUTER JOIN Table_B B
ON A.PK = B.PK
WHERE A.PK IS NULL
OR B.PK IS NULL
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

由于mysql不支持full join,只能通过下面代码模拟实现:

SELECT  A.PK AS A_PK, A.Value AS A_Value, B.PK AS B_PK,
B.Value AS B_Value
 FROM table_a A
 LEFT JOIN table_b B
ON A.PK = B.PK
 WHERE B.PK IS NULL
UNION ALL
 SELECT *
 FROM table_a A
 RIGHT JOIN table_b B
 ON A.PK = B.PK
  WHERE A.PK IS NULL;
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

查询结果: 
数据库左连接、右连接、内连接、全连接笔记_第15张图片

你可能感兴趣的:(数据库)