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 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集合操作符用于组合两个数据 具有相同数据类型的列的表。 当执行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
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操作符只是用于组合两个或多个SELECT语句。
而JOIN用于从每个表中选择行,可以通过内、外、左或右方法。
参考这里和这里。用例子来解释会更好。
它们是完全不同的东西。
连接允许您在不同的表中关联相似的数据。
联合将两个不同查询的结果作为一个记录集返回。
推荐文章
- 将值从同一表中的一列复制到另一列
- 什么是数据库池?
- GROUP BY with MAX(DATE)
- 删除id与其他表不匹配的sql行
- 等价的限制和偏移SQL Server?
- 关于数据库,每个开发人员应该知道些什么?
- 是什么导致这个ActiveRecord::ReadOnlyRecord错误?
- 为什么我不能在DELETE语句中使用别名?
- 在SQL Server Management Studio中保存带有标题的结果
- "where 1=1"语句
- 如何选择一个记录和更新它,与一个单一的查询集在Django?
- 多语句表值函数vs内联表值函数
- 是使用各有一个模式的多个数据库更好,还是使用一个数据库有多个模式更好?
- 如何从Oracle的表中获取列名?
- NOLOCK提示在SELECT语句中的作用