JOIN和UNION的区别是什么?

JOINUNION之间的区别是什么?我能举个例子吗?

538389 次浏览

UNION将来自查询的行依次排列,而JOIN生成笛卡尔积并对其进行子集——完全不同的操作。UNION的简单例子:

mysql> SELECT 23 AS bah
-> UNION
-> SELECT 45 AS bah;
+-----+
| bah |
+-----+
|  23 |
|  45 |
+-----+
2 rows in set (0.00 sec)

类似的JOIN的简单例子:

mysql> SELECT * FROM
-> (SELECT 23 AS bah) AS foo
-> JOIN
-> (SELECT 45 AS bah) AS bar
-> ON (33=33);
+-----+-----+
| foo | bar |
+-----+-----+
|  23 |  45 |
+-----+-----+
1 row in set (0.01 sec)

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

联盟将两个或多个查询的结果组合成一个结果集,该结果集包含属于联合中所有查询的所有行。

通过使用连接,您可以根据表之间的逻辑关系从两个或多个表中检索数据。联接指示SQL应该如何使用一个表中的数据来选择另一个表中的行。

UNION操作不同于使用join来组合两个表中的列。

联盟的例子:

SELECT 1 AS [Column1], 2 AS [Column2]
UNION
SELECT 3 AS [Column1], 4 AS [Column2]

输出:

Column1    Column2
-------------------
1          2
3          4

加入的例子:

SELECT a.Column1, b.Column2 FROM TableA a INNER JOIN TableB b ON a.Id = b.AFKId

这将输出两个表中条件a.Id = b.AFKId为真的所有行。

记住union将合并结果(SQL 服务器是肯定的)(特性还是错误?)

select 1 as id, 3 as value
union
select 1 as id, 3 as value

id,值

1、3

select * from (select 1 as id, 3 as value) t1 inner join (select 1 as id, 3 as value) t2 on t1.id = t2.id

id值,id值

1、3、1、3

它们是完全不同的东西。

加入允许你在不同的表中关联相似的数据。

联合将两个不同查询的结果作为一个记录集返回。

加入:

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

.列将彼此对齐

联盟:

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

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

联盟:

Enter image description here

加入:

Enter image description here

UNION操作符只是用于组合两个或多个SELECT语句。

而JOIN用于从每个表中选择行,可以通过内、外、左或右方法。

参考在这里在这里。用例子来解释会更好。

  1. SQL JOIN子句用于组合来自数据库中两个或多个表的记录。JOIN是通过使用两个表的公共值来组合来自两个表的字段的一种方法。

  2. SQL UNION操作符组合两个或多个SELECT语句的结果。 UNION中的每个SELECT语句必须具有相同数量的列。列还必须具有相似的数据类型。此外,每个SELECT语句中的列必须按照相同的顺序

例如< p >: 表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;

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

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

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

在抽象上,它们是相似的,因为两个表或结果集被组合在一起,但UNION实际上是用于将具有相同列数的结果集与具有相似数据类型的列组合在一起。STRUCTURE是相同的,只是添加了新的行。

在连接中,您可以将表/结果集与任何可能的结构组合在一起,包括没有共享/相似列的笛卡尔连接。

我们工会

UNION将两个或多个查询的结果组合成一个结果集,该结果集包含属于联合中所有查询的所有行。

UNION Example:
SELECT 121 AS [Column1], 221 AS [Column2]
UNION
SELECT 321 AS [Column1], 422 AS [Column2]
Output:


Column1    Column2
-------------------
121          221
321          422

我们加入

join,您可以根据表之间的逻辑关系从两个或多个表中检索数据。

JOIN Example:
SELECT a.Column1, b.Column2 FROM TblA a INNER JOIN TblB b ON a.Id = b.id


联合运算是垂直行聚合的组合结果, Join操作是列的水平聚合的组合结果

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

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