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


当前回答

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实际上是用于将具有相同列数的结果集与具有相似数据类型的列组合在一起。STRUCTURE是相同的,只是添加了新的行。

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

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

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

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

它们是完全不同的东西。

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

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

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

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

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

记住,union将合并结果(SQL Server)(特性或错误?)

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