UNION 和 UNION ALL

合并查询结果 利用UNION关键字,可以给出多条SELECT语句,并将它们的结果组合成单个结果集。合并时,两个表对应的列数和数据类型必须相同,并且相互对应。

各个SELECT语句之间使用UNION或UNION ALL关键字分隔。

语法格式

SELECT column,... FROM table1 
UNION [ALL] 
SELECT column,... FROM table2

UNION

UNION:会执行去重操作

UNION 操作符返回两个查询的结果集的并集,去除重复记录

在这里插入图片描述

UNION ALL

UNION ALL:不会执行去重操作

UNION ALL 操作符返回两个查询的结果集的并集。对于两个结果集的重复部分,不去重。

 在这里插入图片描述

注意:
执行UNION ALL语句时所需要的资源比UNION语句少。如果明确知道合并数据后的结果数据不存在重复数据,或者不需要去除重复的数据,则尽量使用UNION ALL语句,以提高数据查询的效率。(不用去重提高效率 )

USING 连接

进行连接的时候,SQL99 还支持使用 USING 指定数据表里的 同名字段 进行等值连接。但是只能配合JOIN一起使用

使用 USING 指定数据表里的同名字段后,会自动在两个表中查找指定的字段,根据指定的字段进行等值连接

SELECT e.employee_id, d.department_id
FROM employees e
JOIN departments d
USING (department_id);

在这里插入图片描述

等价于:

SELECT e.employee_id, d.department_id
FROM employees e
JOIN departments d
ON e.department_id = d.department_id;

 在这里插入图片描述

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值