跳到主要内容

JOINs

支持的 Join 类型

join 将两个或多个表中的列组合成一个结果集。Databend 支持以下 join 类型:

示例表

除非明确指定,本页的 join 示例均基于以下表:

表 "vip_info":该表存储 VIP 客户信息。

Client_IDRegion
101Toronto
102Quebec
103Vancouver

表 "purchase_records":该表列出了所有客户的购买记录。

Client_IDItemQTY
100Croissant2,000
102Donut3,000
103Coffee6,000
106Soda4,000

表 "gift":该表列出了 VIP 客户的礼品选项。

Gift
Croissant
Donut
Coffee
Soda

Inner Join

inner join 返回结果集中满足 join 条件的行。

语法

SELECT select_list
FROM table_a
[INNER] JOIN table_b
ON join_condition_1
[[INNER] JOIN table_c
ON join_condition_2]...
提示

关键字 INNER 是可选的。

当你在两个表的公共列上使用等号运算符进行 join 时,可以使用关键字 USING 来简化语法。

SELECT select_list
FROM table_a
JOIN table_b
USING join_column_1
[JOIN table_c
USING join_column_2]...

示例

以下示例返回 VIP 客户的购买记录:

SELECT purchase_records.client_id,
purchase_records.item,
purchase_records.qty
FROM vip_info
INNER JOIN purchase_records
ON vip_info.client_id = purchase_records.client_id;

有关示例中表的定义,请参见 示例表

输出:

|102|Donut|3000
|103|Coffee|6000

Natural Join

natural join 根据两个表中所有具有相同名称的列进行 join。

语法

SELECT select_list
FROM table_a
NATURAL JOIN table_b
[NATURAL JOIN table_c]...

示例

以下示例返回 VIP 客户的购买记录:

SELECT purchase_records.client_id,
purchase_records.item,
purchase_records.qty
FROM vip_info
NATURAL JOIN purchase_records;

有关示例中表的定义,请参见 示例表

输出:

|102|Donut|3,000
|103|Coffee|6,000

Cross Join

cross join 返回一个结果集,其中包括第一个表中的每一行与第二个表中的每一行的组合。

语法

SELECT select_list
FROM table_a
CROSS JOIN table_b

示例

以下示例返回一个结果集,将每个礼品选项分配给每个 VIP 客户:

SELECT *
FROM vip_info
CROSS JOIN gift;

有关示例中表的定义,请参见 示例表

输出:

101|Toronto|Croissant
101|Toronto|Donut
101|Toronto|Coffee
101|Toronto|Soda
102|Quebec|Croissant
102|Quebec|Donut
102|Quebec|Coffee
102|Quebec|Soda
103|Vancouver|Croissant
103|Vancouver|Donut
103|Vancouver|Coffee
103|Vancouver|Soda

Left Join

left join 返回左表中的所有记录,以及右表中匹配的记录。如果没有匹配,则右表的结果为 NULL。

语法

SELECT select_list
FROM table_a
LEFT [OUTER] JOIN table_b
ON join_condition
提示

关键字 OUTER 是可选的。

示例

以下示例返回所有 VIP 客户的购买记录,如果 VIP 客户没有购买记录,则购买记录为 NULL:

SELECT vip_info.client_id,
purchase_records.item,
purchase_records.qty
FROM vip_info
LEFT JOIN purchase_records
ON vip_info.client_id = purchase_records.client_id;

有关示例中表的定义,请参见 示例表

输出:

|101|NULL|NULL
|102|Donut|3000
|103|Coffee|6000

Right Join

right join 返回右表中的所有记录,以及左表中匹配的记录。如果没有匹配,则左表的结果为 NULL。

语法

SELECT select_list
FROM table_a
RIGHT [OUTER] JOIN table_b
ON join_condition
提示

关键字 OUTER 是可选的。

示例

假设我们有以下表:

以下示例返回所有 purchase_records 的 vip_info,如果 purchase_record 没有对应的 vip_info,则 vip_info 为 NULL。

SELECT vip_info.client_id,
vip_info.region
FROM vip_info
RIGHT JOIN purchase_records
ON vip_info.client_id = purchase_records.client_id;

有关示例中表的定义,请参见 示例表

输出:

NULL|NULL
102|Quebec
103|Vancouver
NULL|NULL

Full Outer Join

full outer join 返回两个表中的所有行,匹配的行将组合在一起,没有匹配的行将放置 NULL。

语法

SELECT select_list
FROM table_a
FULL OUTER JOIN table_b
ON join_condition
提示

关键字 OUTER 是可选的。

示例

以下示例返回两个表中所有匹配和不匹配的行:

SELECT vip_info.region,
purchase_records.item
FROM vip_info
FULL OUTER JOIN purchase_records
ON vip_info.client_id = purchase_records.client_id;

有关示例中表的定义,请参见 示例表

输出:

Toronto|NULL
Quebec|Donut
Vancouver|Coffee
NULL|Croissant
NULL|Soda

Left / Right Semi Join

left semi join 返回左表中在右表中有匹配行的行。right semi join 返回右表中在左表中有匹配行的行。

语法

-- Left Semi Join

SELECT select_list
FROM table_a
LEFT SEMI JOIN table_b
ON join_condition

-- Right Semi Join

SELECT select_list
FROM table_a
RIGHT SEMI JOIN table_b
ON join_condition

示例

以下示例返回有购买记录的 VIP 客户(Client_ID & Region):

SELECT *
FROM vip_info
LEFT SEMI JOIN purchase_records
ON vip_info.client_id = purchase_records.client_id;

有关示例中表的定义,请参见 示例表

输出:

102|Quebec
103|Vancouver

以下示例返回 VIP 客户的购买记录(Client_ID、Item 和 QTY):

SELECT *
FROM vip_info
RIGHT SEMI JOIN purchase_records
ON vip_info.client_id = purchase_records.client_id;

有关示例中表的定义,请参见 示例表

输出:

|102|Donut|3000
|103|Coffee|6000

Left / Right Anti Join

left anti join 返回左表中在右表中没有匹配行的行。right anti join 返回右表中在左表中没有匹配行的行。

语法

-- Left Anti Join

SELECT select_list
FROM table_a
LEFT ANTI JOIN table_b
ON join_condition

-- Right Anti Join

SELECT select_list
FROM table_a
RIGHT ANTI JOIN table_b
ON join_condition

示例

以下示例返回没有购买记录的 VIP 客户(Client_ID & Region):

SELECT *
FROM vip_info
LEFT ANTI JOIN purchase_records
ON vip_info.client_id = purchase_records.client_id;

有关示例中表的定义,请参见 示例表

输出:

101|Toronto

以下示例返回非 VIP 客户的购买记录(Client_ID、Item 和 QTY):

SELECT *
FROM vip_info
RIGHT ANTI JOIN purchase_records
ON vip_info.client_id = purchase_records.client_id;

有关示例中表的定义,请参见 示例表

输出:

|100|Croissant|2000
|106|Soda|4000