13-mysql数据查询语言(DQL)-联合查询

联合查询

联合查询的关键字是: 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; 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值