JOIN和UNION的区别是什么?我能举个例子吗?


当前回答

我喜欢把一般的区别想成:

join连接表 UNION (et all)组合查询。

其他回答

Union使两个查询看起来像一个查询。连接用于在单个查询语句中检查两个或多个表

加入:

连接用于显示具有相同或的列 不同表的不同名称。显示的输出 将单独显示所有列。也就是 列将彼此对齐。

联盟:

UNION集合操作符用于组合两个数据 具有相同数据类型的列的表。 当执行UNION时,来自两个表的数据将被删除 在具有相同数据类型的单列中收集。

例如:

请看下面两个表:

Table t1
Articleno article price manufacturer_id
1 hammer 3 $ 1
2 screwdriver 5 $ 2

Table t2
manufacturer_id manufacturer
1 ABC Gmbh
2 DEF Co KG

现在要执行JOIN类型,查询如下所示。

SELECT articleno, article, manufacturer
FROM t1 JOIN t2 ON (t1.manufacturer_id =
t2.manufacturer_id);

articelno article manufacturer
1 hammer ABC GmbH
2 screwdriver DEF Co KG

这是一个连接。

UNION意味着您必须将表或结果集与 相同数量和类型的列,然后加上这个 表/结果集在一起。看看这个例子:

Table year2006
Articleno article price manufacturer_id
1 hammer 3 $ 1
2 screwdriver 5 $ 2

Table year2007
Articleno article price manufacturer_id
1 hammer 6 $ 3
2 screwdriver 7 $ 4

SELECT articleno, article, price, manufactruer_id
FROM year2006
UNION
SELECT articleno, article, price, manufacturer_id
FROM year2007

articleno article price manufacturer_id
1 hammer 3 $ 1
2 screwdriver 5 $ 2
1 hammer 6 $ 3
2 screwdriver 7 $ 4

你可能会看到对两者相同的解释,但这完全令人困惑。

联盟:

加入:

连接和联合可用于组合来自一个或多个表的数据。不同之处在于数据是如何组合的。

简单来说,连接将数据合并到新的列中。如果两个表连接在一起,那么来自第一个表的数据将显示在同一行中的一组列中,与第二个表的列一起显示。

联合将数据合并到新的行中。如果两个表“联合”在一起,那么来自第一个表的数据在一组行中,来自第二个表的数据在另一组行中。结果是一样的。

SQL JOIN子句用于组合来自数据库中两个或多个表的记录。JOIN是通过使用两个表的公共值来组合来自两个表的字段的一种方法。 SQL UNION操作符组合两个或多个SELECT语句的结果。 UNION中的每个SELECT语句必须具有相同数量的列。列还必须具有相似的数据类型。此外,每个SELECT语句中的列必须具有相同的顺序。

例如: 表1客户/表2订单

内连接:

SELECT ID, NAME, AMOUNT, DATE
FROM CUSTOMERS

INNER JOIN ORDERS

ON CUSTOMERS.ID = ORDERS.CUSTOMER_ID; 

联盟:

SELECT ID, NAME, AMOUNT, DATE

FROM CUSTOMERS

LEFT JOIN ORDERS

ON CUSTOMERS.ID = ORDERS.CUSTOMER_ID 
UNION
SELECT ID, NAME, AMOUNT, DATE
FROM CUSTOMERS

RIGHT JOIN ORDERS

ON CUSTOMERS.ID = ORDERS.CUSTOMER_ID;