子查询和组合查询

子查询

SELECT 语句是 SQL 的查询。 假如要从多个表中过滤数据,SQL 还允许创建子查询(subquery),即嵌套在其他查询中的查询(在一个 select 语句中,嵌入了另外一个 select 语句, 那么被嵌入的 select 语句称之为子查询语句)

主查询 主要查询的对象,第一条 select 语句

主查询和子查询的关系: 子查询是嵌入到主查询中 子查询是辅助主查询的,要么充当条件,要么充当数据源 子查询是可以独立存在的语句,是一条完整的 select

语句 子查询分类

标量 子查询: 子查询返回的结果是一个数据(一行一列)

列 子查询: 返回的结果是一列(一列多行)

行 子查询: 返回的结果是一行(一行多列)

标量子查询 查询班级学生平均年龄 查询大于平均年龄的学生 查询班级学生的平均身高

select * from students where age > (select avg(age) from students);

列级子查询 查询还有学生在班的所有班级名字 找出学生表中所有的班级 id 找出班级表中对应的名字

select name from classes where id in (select cls_id from students);

行级子查询 需求: 查找班级年龄最大,身高最高的学生 行元素: 将多个字段合成一个行元素,在行级子查询中会使用到行元素

select * from students where (height,age) = (select max(height),max(age) from students);

子查询中特定关键字使用

in 范围

格式: 主查询 where 条件 in (列子查询)

any 相当于或条件

格式: 主查询 where 条件 (比较运算符) any (列子查询)

all 相当于and

格式: 主查询 where 条件 (比较运算符) all (列子查询)
组合查询

可用 UNION 操作符来组合数条SQL查询。利用 UNION ,可给出多条SELECT 语句,将它们的结果组合成单个结果集。

查询语句1 UNION 查询语句2

select 列1,列2 from 表名 where 条件 union select 列1,列2 from 表名 where 条件;

注意:使用以上语句会消除重复的行,因为两个查询条件可能会匹配到相同的记录,但是最终只会返回一条。

查询语句1 UNION ALL 查询语句2

select 列1,列2 from 表名 where 条件 UNION ALL select 列1,列2 from 表名 where 条件;

使用 UNION ALL ,MySQL不取消重复的行

注意 UNION 与 WHERE

UNION 几乎总是完成与多个WHERE 条件相同的工作。 UNION ALL 为 UNION 的一种形式,它完成WHERE 子句完成不了的工作。如果确实需要每个条件的匹配行全部出现(包括重复行),则必须使用 UNION ALL 而不是 WHERE 。

SELECT 语句的输出用 ORDER BY 子句排序。在用 UNION 组合查询时,只能使用一条 ORDER BY 子句,它必须出现在最后一条 SELECT 语句之后。对于结果集,不存在用一种方式排序一部分,而又用另一种方式排序另一部分的情况,因此不允许使用多条ORDER BY 子句。

你可能感兴趣的:(子查询和组合查询)