mysql联合查询(UNION)

mysql联合查询(UNION)

下面我就直接po截图和代码mysql

#联合查询
/*
union 联合 合并:将多条查询语句的结果合并成一个结果

语法:
查询语句1
union
查询语句2
union
...


应用场景:
要查询的结果来自于多个表,且多个表没有直接的链接关系,但查询的信息一致时

特色:★
一、要求多条查询语句的查询列数是一致的!
二、要求多条查询语句的查询的每一列的类型和顺序最好一致
三、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';

使用UNIONsql

使用UNION ALLcode

#联合查询
/*
union 联合 合并:将多条查询语句的结果合并成一个结果blog

语法:
查询语句1
union
查询语句2
union
...io


应用场景:
要查询的结果来自于多个表,且多个表没有直接的链接关系,但查询的信息一致时class

特色:★
一、要求多条查询语句的查询列数是一致的!
二、要求多条查询语句的查询的每一列的类型和顺序最好一致
三、union关键字默认去重,若是使用union all 能够包含重复项test

*/email