联合查询
联合查询的关键字是: union。
连接查询的关键字是: join。
但,在mysql手册中, join这个连接查询,往往都翻译为“联合查询”。
但在绝大多数的中文书籍和文章中,join被翻译为“连接查询”。
基本含义
将两个“字段一致”的查询语句所查询到的结果以“纵向堆叠”的方式合并到一起,成为一个新的结果集。
结果集是两个独立select查询语句的结果行数的和。
如图所示:
联合查询就是将两个select语句的查询结果“层叠”到一起成为一个“大结果”。
两个查询结果能够进行“联合”的先觉条件是:结果字段数相等。
语法形式
语法
:
select 语句1 union [ALL | DISTINCT] select语句2;
说明:
-
两个select语句的查询结果的字段需要保持一致:个数必须相同,对应顺序上的字段类型也应该相同。
-
ALL | DISTINCT表示两表的数据联合后是否需要消除相同行(数据)。
- ALL表示不消除(全部取得)
- DISTINCT表示要消除。
- 默认不写就会消除。
-
应该将这个联合查询的结果理解为最终也是一个“表格数据”,且默认使用第一个select语句中的字段名;
-
如果要对整个查询结果进行order by或limit操作,则需要将两个select语句各自用括号括起来,类似这样:
(select...) union (select...) order by XXX limit m,n;
-
第一个select语句的字段可以做别名,但如果做别名,则后续的where,group,order by等子句就必须使用该别名。
联合查询示例
# 这里会自动“消除重复行”
select id , f1, f2 from jointable1 union select id2, c1, c2 from jointable2;
# 这里明确声明不要消除重复行
select id , f1, f2 from jointable1 union all select id2, c1, c2 from jointable2;
# 使用排序,这里不能使用id2
(select id, f1, f2 from jointable1) union (select id2, c1, c2 from jointable2) order by id;
# 这里不能使用id了
(select id as nid, f1, f2 from jointable1) union (select id2, c1, c2 from jointable2) order by nid;