https://www.cnblogs.com/poloyy/category/1683347.html
前言
union 的语法格式
语法格式说明
- sql1、sql2、sql3:平时写的查询 sql,可以连接很多条 sql
- ALL:可选参数,返回所有结果集,包含重复数据
- distinct:可选参数,删除结果集中重复的数据(默认只写 union 也会删除重复数据,所以不加也没事)
先看看dept、emp表有什么数据
dept表
emp表
union all 的栗子
select * from emp as a left join dept as b on a.dept_id = b.id union all right = b.id;
union 的栗子
union = b.id;
上图是去重之后的结果,而没有去重的结果可以看union all 的栗子或者下图
红色圈住的部分就是重复的数据,union 会进行去重,只保留一份数据
知识点(重点)
union 连接的两条 sql ,各自指定的字段顺序不相同的栗子
从上图可以看出,第二条 sql 查出来的字段顺序和最终结果集字段顺序明显不一样,导致数据错乱的问题
所以!!union 连接的每条 sql 指定的字段顺序最好一致!!
所以!!union 连接的每条 sql 指定的字段顺序最好一致!!
所以!!union 连接的每条 sql 指定的字段顺序最好一致!!
select id,name,dept_id,is_enable 0