RIGHT JOIN
右联接(RIGHT JOIN)表示右外联接,使用该语句可以返回右表中的所有记录以及左表与右表中联结字段相等的记录。
背景信息
外联接(OUTTER JOIN)是使用比较运算符对两个表中的数据进行比较,联接结果不仅包含符合联接条件的行,同时也包含不符合条件的行。
外联接包括全联接(FULL JOIN)、左联接(LEFT JOIN)和右联接(RIGHT JOIN)。外联接返回满足联接条件的所有行,同时从一个表返回没有使用的行,在另一个表相应位置填充 NULL。
本文主要提供右联接的示例指导,全联接相关示例请参见 全联接,左联接相关示例请参见 左联接。
RIGHT JOIN 语法
外联接语句中一般包括左表和右表,出现在 JOIN 子句最左边的为左表,出现在 JOIN 子句最右边的为右表。
RIGHT JOIN 的语法格式如下:
SELECT select_list FROM table_name1 RIGHT JOIN table_name2 ON join_condition
[ WHERE query_condition ]
[ ORDER BY column_list ];
其中,table_name1 为左表,table_name2 为右表。
示例
创建示例表并插入适当数据。
CREATE TABLE tbl_a(id INT NOT NULL PRIMARY KEY, name VARCHAR(50));
Query OK, 0 rows affected
CREATE TABLE tbl_b(number INT NOT NULL PRIMARY KEY, value INT);
Query OK, 0 rows affected
CREATE TABLE tbl_c(id INT NOT NULL , name VARCHAR(50));
Query OK, 0 rows affected (0.081 sec)
INSERT INTO tbl_a VALUES(1,'ab'),(2,'cd'),(3,'ef'),(4,'gh');
Query OK, 4 rows affected
Records: 4 Duplicates: 0 Warnings: 0
INSERT INTO tbl_b VALUES(1,1001),(3,1003),(5,1005);
Query OK, 3 rows affected
Records: 3 Duplicates: 0 Warnings: 0
INSERT INTO tbl_c VALUES(1,'aa'),(2,'dd'),(6,'ee'),(7,'hh'),(9,'xx');
Query OK, 5 rows affected (0.005 sec)
Records: 5 Duplicates: 0 Warnings: 0
简单右联接查询
如果 JOIN 返回的数据除了符合联接条件和过滤条件的数据外,还包括右表里满足右表的过滤条件但不满足联接条件的数据时,就可以使用右外联接(RIGHT OUTER JOIN),或简写为右联接(RIGHT JOIN)。右联接返回的结果里属于左表的数据如果不存在,则该列返回 NULL。
示例 1:将表 tbl_a 和表 tbl_b 执行右联接查询,并获取返回结果。
SELECT * FROM tbl_a;
+------+------+
| id | name |
+------+------+
| 1 | ab |
| 2 | cd |
| 3 | ef |
| 4 | gh |
+------+------+
4 rows in set
SELECT * FROM tbl_b;
+--------+-------+
| number | value |
+--------+-------+
| 1 | 1001 |
| 3 | 1003 |
| 5 | 1005 |
+--------+-------+
3 rows in set
SELECT * FROM tbl_a RIGHT JOIN tbl_b ON tbl_a.id=tbl_b.number;
+------+------+--------+-------+
| id | name | number | value |
+------+------+--------+-------+
| 1 | ab | 1 | 1001 |
| 3 | ef | 3 | 1003 |
| NULL | NULL | 5 | 1005 |
+------+------+--------+-------+
3 rows in set
复杂右联接查询
示例如下:
SELECT * FROM tbl_a a INNER JOIN tbl_b b RIGHT JOIN tbl_c c ON c.id=b.number ON a.name=c.name;
Empty set (0.009 sec)
右联接和 WHERE 子句联合使用
您可以使用右联接获取联接结果,再使用 WHERE 子句对联接结果进行过滤。
示例 2:将表 tbl_a 和表 tbl_b 执行右联接查询后,返回 tbl_b 表中 value=1003 的数据。
SELECT * FROM tbl_a;
+------+------+
| id | name |
+------+------+
| 1 | ab |
| 2 | cd |
| 3 | ef |
| 4 | gh |
+------+------+
4 rows in set
SELECT * FROM tbl_b;
+--------+-------+
| number | value |
+--------+-------+
| 1 | 1001 |
| 3 | 1003 |
| 5 | 1005 |
+--------+-------+
3 rows in set
SELECT * FROM tbl_a RIGHT JOIN tbl_b ON tbl_a.id=tbl_b.number WHERE tbl_b.value=1003;
+------+------+--------+-------+
| id | name | number | value |
+------+------+--------+-------+
| 3 | ef | 3 | 1003 |
+------+------+--------+-------+
1 row in set