JOIN和UNION的区别是什么?我能举个例子吗?
当前回答
你可能会看到对两者相同的解释,但这完全令人困惑。
联盟:
加入:
其他回答
记住,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
Union使两个查询看起来像一个查询。连接用于在单个查询语句中检查两个或多个表
乌辛联盟
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
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为真的所有行。
连接和联合可用于组合来自一个或多个表的数据。不同之处在于数据是如何组合的。
简单来说,连接将数据合并到新的列中。如果两个表连接在一起,那么来自第一个表的数据将显示在同一行中的一组列中,与第二个表的列一起显示。
联合将数据合并到新的行中。如果两个表“联合”在一起,那么来自第一个表的数据在一组行中,来自第二个表的数据在另一组行中。结果是一样的。
推荐文章
- 在SQL中更新多个列
- 如何删除表中特定列的第一个字符?
- MySQL OR与IN性能
- 为什么我应该使用基于文档的数据库而不是关系数据库?
- 哪个更快/最好?SELECT *或SELECT columnn1, colum2, column3等
- 将值从同一表中的一列复制到另一列
- 什么是数据库池?
- GROUP BY with MAX(DATE)
- 删除id与其他表不匹配的sql行
- 等价的限制和偏移SQL Server?
- 关于数据库,每个开发人员应该知道些什么?
- 是什么导致这个ActiveRecord::ReadOnlyRecord错误?
- 为什么我不能在DELETE语句中使用别名?
- 在SQL Server Management Studio中保存带有标题的结果
- "where 1=1"语句