联合查询学习
/
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
使用UNION ALL