【数据库】MySQL之union联合查询

联合查询:

关键字union,作用就是将多条查询语句的结果合并成一个结果集。

案例:(查询部门编号大于100或名字中含有a字符的员工信息)

bash 复制代码
select * from employees where department_id>100 or last_name like '%a%';

用联合查询演示:

sql 复制代码
select * from employees where department_id>100
union
select * from employees where last_name like '%a%';

union是应用场景:

比如在我们有个数据库中的老师表和学生表,两者之间没有直接的关联关系,但是又有一些共通性,但是现在我们想要查询学校所有男老师和男学生的信息(学生和老师的编号,姓名,出现日期,性别),这个时候就是应用union的时候。

sql 复制代码
SELECT `tno` 编号,`tname`,`tsex`,`tbirthday`
FROM `teachers`
WHERE `tsex`='男'
UNION
SELECT `sno`,`sname`,`ssex`,`sbirthday`
FROM `students`
WHERE `ssex`='男';

联合查询的特点:

  • 联合查询的两个子查询的查询字段个数要一致
  • 要求联合查询的子查询的查询列表顺序要在内容上保持一致
  • 使用union联合默认会自动去重,如果不想去重可以将union改为union all
相关推荐
zongzizz1 分钟前
Oracle 11g 两节点rac在机房断电重启后PL/SQL和客户端连接数据库报错ORA-12541
数据库·oracle
qq_417695057 分钟前
实战:用OpenCV和Python进行人脸识别
jvm·数据库·python
身如柳絮随风扬7 分钟前
什么是左匹配规则?
数据库·sql·mysql
xinhuanjieyi15 分钟前
ruoyimate导入sql\antflow\bpm_init_db.sql报错
android·数据库·sql
哈__24 分钟前
从内核阻断 SQL 注入:金仓 KingbaseES SQL 防火墙技术解析与实践
数据库·sql
jiankeljx30 分钟前
mysql之如何获知版本
数据库·mysql
_oP_i1 小时前
SQLBot 系统数据库字段
数据库
我真会写代码1 小时前
Redis高频面试题(含标准答案,覆盖基础+进阶+实战)
数据库·redis·缓存
2301_793804691 小时前
用Python和Twilio构建短信通知系统
jvm·数据库·python
小李来了!1 小时前
数据库DDL、DML、DQL、DCL详解
数据库·mysql