史上最简单的 MySQL 教程(三十)「联合查询」

温馨提示:本系列博文已经同步到 GitHub,地址为「mysql-tutorial」,欢迎感兴趣的童鞋StarFork,纠错。

联合查询

联合查询union,将多次查询(多条select语句)的结果,在字段数相同的情况下,在记录的层次上进行拼接。

基本语法

联合查询由多条select语句构成,每条select语句获取的字段数相同,但与字段类型无关。

  • 基本语法select 语句1 + union + [union选项] + select 语句2 + ...;
  • union 选项:与select选项一样有两种
    • all:无论重复与否,保留所有记录;
    • distinct:表示去重,为默认选项。

执行如下 SQL 语句,进行测试:

-- 联合查询,默认去重
select * from class
union distinct
select * from class;

-- 联合查询,保留所有记录
select * from class
union all
select * from class;
union1

如上图所示,展示了联合查询的两种形式。特别地,联合查询只要求字段数相同,而跟类型无关。执行如下 SQL 语句,进行测试:

-- 联合查询,字段数相同,类型不同
select id, grade, room from class
union distinct
select name, age, id from student;
UNION2

如上图所示,联合查询只保留了第一张表的字段,而不保留第二张表的字段。

意义

联合查询的意义有两种,分别为:

  • 查询同一张表,例如查询学生信息,要求男生按年龄升序排序,女生按年龄降序排序;
  • 多表查询,多张表的结构是完全一样的,保持的数据结构也是一样的。

此外,如果数据量非常的大,就要进行分表(垂直分表和水平分表),而分表的依据无外乎数据多不多和常不常用。

排序

首先,让我们看看student表中的数据:

student

接下来,给出一个需求:student表中,让男生按年龄升序排序,让女生按年龄降序排序。根据我们刚刚学到的联合查询,貌似很容易啊!执行如下 SQL 语句,进行测试:

-- 在 student 表中,按年龄,男升女降
select * from student where gender = "boy" order by age asc
union
select * from student where gender = "girl" order by age desc;
order1

如上图所示,呃,好吧,貌似出错啦!这是因为要想在联合查询中使用order by,我们必须将select语句用括号括起来。执行如下 SQL 语句,进行测试:

-- 在 student 表中,按年龄,男升女降
(select * from student where gender = "boy" order by age asc)
union
(select * from student where gender = "girl" order by age desc);
order2

如上图所示,啊,我们都已经将select语句用括号括起来了,但是男生和女生也没有按我们的目的实现啊!好吧,这是因为要想在联合查询中使order by生效,我们必须将其与limit搭配使用,而limit的限定数,我们设置为一个非常大的数即可。执行如下 SQL 语句,进行测试:

-- 在 student 表中,按年龄,男升女降
(select * from student where gender = "boy" order by age asc limit 666)
union
(select * from student where gender = "girl" order by age desc limit 666);
order

如上图所示,显然,这次咱们的目的实现啦!


温馨提示:符号[]括起来的内容,表示可选项;符号+,则表示连接的意思。


———— ☆☆☆ —— 返回 -> 史上最简单的 MySQL 教程 <- 目录 —— ☆☆☆ ————

原创声明,本文系作者授权云+社区-专栏发表,未经许可,不得转载。

如有侵权,请联系 zhuanlan_guanli@qq.com 删除。

编辑于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏xingoo, 一个梦想做发明家的程序员

JSP中文乱码问题

之前总是碰到JSP页面乱码的问题,每次都是现在网上搜,然后胡乱改,改完也不明白原因。 这次正好作下总结,中文乱码就是因为编码不符,可能出现乱码有四个地方: ...

2089
来自专栏坚毅的PHP

node.js学习与应用

学习资料 入门: 小白篇 http://samsungapps.csdn.net/text.html?arcid=311044 了解了 npm,类似于pytho...

3186
来自专栏pangguoming

web.xml中load-on-startup的作用

如下一段配置,熟悉DWR的再熟悉不过了: <servlet>    <servlet-name>dwr-invoker</servlet-name>    <s...

3267
来自专栏V站

Python的flask:models.py来创建mysql数据库

1936
来自专栏禹都一只猫博客

Python的flask:models.py来创建mysql数据库

4339
来自专栏有趣的Python

代码模板:python-基础-5(菲波那切数列)

选自python高效开发实战。 # -*- coding: utf-8 -*- #!/usr/bin/env python ## linux系统告诉系统pyth...

2836
来自专栏MasiMaro 的技术博文

Windows内核函数

在驱动中一般使用的是ANSI字符串和宽字节字符串,在驱动中我们仍然可以使用C中提供的字符串操作函数,但是在DDK中不提倡这样做,由于C函数容易导致缓冲区溢出漏洞...

644
来自专栏用户2442861的专栏

chrome调试工具常用功能整理

chrome devtools 中 Elements panel 是审查 dom 元素和 css 的, 可以实时修改 dom/css.

441
来自专栏挖坑填坑

Angular练习之animations动画

让我们隆重介绍Angular动画。Angular是基于最新的Web Animations API,我们使用动画触发器(animation triggers)来定...

631
来自专栏农夫安全

SQL注入精讲

SQL注入的三大块: GET POST Cookie GET GET提交方式:在URL传递参数的请求,就是GET方式,是以name=value的方式出现 例如:...

3199

扫描关注云+社区