那union和join区别呢?
UNION和JOIN都是SQL中的操作命令,用于合并数据,但是他们的应用场景和用法上有明显的区别:
- 合并方式:UNION是将两个或多个查询结果纵向合并起来,即将多个查询的结果集“堆叠”起来,产生新的结果集。他们通常用于同构的数据,即从不同的表或不同查询中筛选相同类型的数据。例如,从销售表中关联出今年的销售记录和去年的销售记录。
JOIN则是在水平方向上合并表,即在一行内将多个表的列联接起来。他们适用于异构的数据,即需要从不同的表中按照某种相关的条件拉取不同类型的数据。例如,订单表中的客户ID和客户表中的客户ID进行匹配,显示出每笔订单和其对应的客户信息。
-
结果表的列数:UNION操作是把多个查询结果合并到一个结果集里,列数仍然和单个查询结果的列数相同。而JOIN操作后的结果集的列数通常是参与运算的两个表的列数之和(除非有少量列进行了省略)。
-
数据关系:UNION操作一般用于表与表之间没有关系,仅仅是需要合并他们的数据时。JOIN操作用于表与表之间有关系,需要通过此关系来进行数据的查询。
-
去重:UNION默认会去重,而JOIN不会。