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


当前回答

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

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

其他回答

它们是完全不同的东西。

连接允许您在不同的表中关联相似的数据。

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

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

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

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

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)

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; 

乌辛联盟

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