JOIN和UNION的区别是什么?我能举个例子吗?
当前回答
在抽象上,它们是相似的,因为两个表或结果集被组合在一起,但UNION实际上是用于将具有相同列数的结果集与具有相似数据类型的列组合在一起。STRUCTURE是相同的,只是添加了新的行。
在连接中,您可以将表/结果集与任何可能的结构组合在一起,包括没有共享/相似列的笛卡尔连接。
其他回答
联合操作是行垂直聚合的组合结果, Join操作是列的水平聚合的组合结果。
在抽象上,它们是相似的,因为两个表或结果集被组合在一起,但UNION实际上是用于将具有相同列数的结果集与具有相似数据类型的列组合在一起。STRUCTURE是相同的,只是添加了新的行。
在连接中,您可以将表/结果集与任何可能的结构组合在一起,包括没有共享/相似列的笛卡尔连接。
我喜欢把一般的区别想成:
join连接表 UNION (et all)组合查询。
UNION将两个或多个查询的结果组合成一个结果集,该结果集包含属于联合中所有查询的所有行。
通过使用join,可以根据表之间的逻辑关系从两个或多个表中检索数据。联接指示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操作符只是用于组合两个或多个SELECT语句。
而JOIN用于从每个表中选择行,可以通过内、外、左或右方法。
参考这里和这里。用例子来解释会更好。
推荐文章
- 在SQL server查询中将NULL替换为0
- 在SQL中修改表的模式名
- 如何在SQL Server 2005的一条语句中更新两个表?
- 如何创建临时表与SELECT * INTO tempTable从CTE查询
- 用于查找计数为>的记录的SQL查询
- “从Table1左连接Table2”和“从Table2右连接Table1”可以互换吗?
- 在SQL Server的选择语句中使用带TOP的变量,而不是动态的
- 自然连接和内部连接的区别
- MySQL现在()+1天
- 在SQL中转换月号到月名函数
- 不可重复读和幻影读的区别是什么?
- 改变一个varchar列的最大长度?
- 外键约束:何时使用ON UPDATE和ON DELETE
- 连接查询vs多个查询
- 暂时关闭约束(MS SQL)