联合查询学习
/
union 联合 合并:将多条查询语句的结果合并成一个结果
语法:
查询语句1
union
查询语句2
union

应用场景:
要查询的结果来自于多个表,且多个表没有直接的连接关系,但查询的信息一致时
特点:★
1、要求多条查询语句的查询列数是一致的!
2、要求多条查询语句的查询的每一列的类型和顺序最好一致
3、union关键字默认去重,如果使用union all 可以包含重复项
/
USE myemployees;
#引入的案例:查询部门编号>90或邮箱包含a的员工信息
#
SELECT FROM employees WHERE department_id > 90 OR email LIKE ‘%a%’;
#使用UNION联合查询
SELECT
FROM employees WHERE department_id > 90
UNION
SELECT * FROM employees WHERE email LIKE ‘%a%’;
#
USE test;
#案例:查询中国用户中女性的信息以及外国用户中女性的用户信息
SELECT c.c_id, c.c_name, c.c_sex FROM china c WHERE c_sex = ‘女’
UNION
SELECT f.f_id, f.f_name, f.f_sex FROM foreignUser f WHERE f_sex = ‘female’;
#china表和foreignUser表中都有66号韩梅梅(UNION会去重)
SELECT c.c_id, c.c_name FROM china c WHERE c_sex = ‘女’
UNION
SELECT f.f_id, f.f_name FROM foreignUser f WHERE f_sex = ‘female’;
#china表和foreignUser表中都有66号韩梅梅(UNION ALL 不会去重)
SELECT c.c_id, c.c_name FROM china c WHERE c_sex = ‘女’
UNION ALL
SELECT f.f_id, f.f_name FROM foreignUser f WHERE f_sex = ‘female’;
使用UNION
2020.4.8 - 图2

使用UNION ALL
2020.4.8 - 图3