**一、JOIN运算**
JOIN是用来从多张相关的表中抽取所需的信息并将其结合到一个单一的结果集中的一种机制。它主要基于共同字段(即关联键)上的等值关系执行匹配。
1. **内连接(INNER JOIN)**
内连接返回的是两表间存在交集部分的所有行。例如:
sql
SELECT Orders.OrderID, Customers.CustomerName
FROM Orders
INNER JOIN Customers ON Orders.CustomerID = Customers.CustomerID;
这个查询会找出Orders表中的每个订单与其对应的CustomerName,在Customers表通过相同的CustomerID相联接。
2. **左外连接(LEFT OUTER JOIN / LEFT JOIN)**
左外部连接不仅包含所有满足ON子句条件的行,还包括左侧表全部记录,右侧无对应则填充NULL。
3. **右外连接(RIGHT OUTER JOIN / RIGHT JOIN)**
与此相反,右外连接包括了右边表所有的记录以及左边符合JOIN条件的部分;对于左边没有找到相应匹配项的,则用NULL填补缺失的列。
4. **全外连接(FULL OUTER JOIN / FULL JOIN)**
全部外连接同时包含了左右两侧表不重复的所有纪录,当某侧无法完成配对时,另一方的相关字段显示为 NULL 值。
5. **自连接(Self Join)**
自连接是一种特殊的join形式,同一个表按照某种规则多次引用自身来进行比较或者提取相关数据。
**二、 UNION 操作符**
UNION 是另一种融合数据的方法,但它并不依赖于共享的关键字,而是简单地将具有相同结构的不同SELECT语句的结果集合在一起,去重后形成一个新的结果集。
sql
(SELECT column_name(s)
FROM table1)
UNION
(SELECT column_name(s)
FROM table2);
上述 SQL 查询首先独立运行每一个内部选择语句,然后把各自的非重复行整合成一份统一的新列表。注意各 select 子句必须有完全一致的数量及类型的输出字段才能正确联合起来。
总结来说,JOIN主要用于处理相互有关联的关系型数据之间的集成需求,而UNION更适用于收集同类但来源不同的数据集合,去除其中的冗余实现整体视角下的唯一视图展示。理解并熟练掌握这两个工具的应用场景及其差异性特征能够极大地提升我们在数据分析乃至复杂业务逻辑构建过程的工作效率。
标签: sql如何把两张表合并