分组函数是对数据行的集合进行操作并按组给出一个结果,这个结果可直接输出,或者用来做判断条件。
单行函数和分组函数区别
1.单行输入单行输出;
2.一组或多组输入输出只有一个结果;
分组函数常用到一下五个函数:
• MIN
• MAX
MIN和MAX函数主要是返回每组的最小值和最大值。
MIN和MAX可以用于任何数据类型
– 查询入职日期最早和最晚的、
• SUM
• AVG
– SUM和AVG函数分别返回每组的总和及平均值。
SUM和AVG函数都是只能够对数值类型的列或表达式操作。
– 查询职位以SALES开头的所有员工平均工资、最低工资、最高工资、
工资和。
• COUNT
COUNT函数的主要功能是返回满足条件的每组记录条数。
查询部门30有多少个员工
组函数中distinct
DISTINCT会消除重复记录后再使用组函数
分组函数中空值处理
在分组函数中使用ifnull
-ifnull 函数可以使函数强制包含含有空值的记录
创建数据组
用group by子句创建数据组
通过 GROUP BY 子句可将表中满足WHERE条件的记录按照
指定的列划分成若干个小组
– 其中GROUP BY子句指定要分组的列
-GROUP BY 所指定的列并不是必须出现在SELECT 列表中。
排除组结果
不能在where语句中限制组
可以通过having子句限制组
• 使用 HAVING 子句限制组
– 记录已经分组.
– 使用过组函数.
– 与 HAVING 子句匹配的结果才输出
having放group by order by后固定语法
• SELECT语句执行过程:
– 1.通过FROM子句中找到需要查询的表;
– 2.通过WHERE子句进行非分组函数筛选判断;
– 3.通过GROUP BY子句完成分组操作;
– 4.通过HAVING子句完成组函数筛选判断;
– 5.通过SELECT子句选择显示的列或表达式及组函数;
– 6.通过ORDER BY子句进行排序操作。
子查询概述
-括号内的查询叫子查询,先于主查询执行。
• 子查询的结果被主查询(外部查询)使用
• expr operator包括比较运算符。
– 单行运算符:>、=、>=、<、<>、<=
– 多行运算符: IN、ANY、ALL
-子查询可以嵌入以下SQL子句中:
-where子句
-having子句
-from子句
in的使用
any的使用
any:表示和子查询的任意一行结果进行比较,有一个满足条件即可。
• < ANY:表示小于子查询结果集中的任意一个,即小于最
大值就可以。
• > ANY:表示大于子查询结果集中的任意一个,即大于最
小值就可以。
• = ANY:表示等于子查询结果中的任意一个,即等于谁都
可以,相当于IN。
all的使用
all :表示和子查询的所有行结果进行比较,每一行都必须满足条件。
• < ALL:表示小于子查询结果集中的所有行,即小于最小
值。
• > ALL:表示大于子查询结果集中的所有行,即大于最大
值。
• = ALL :表示等于子查询结果集中的所有行,即等于所有
值,通常无意义。
子查询中的空值
子查询返回的结果中含有空值
上面的SQL语句试图查找出没有下属的雇员,逻辑上,这个SQL语句应该
会返回8条记录,但是却一条也没返回,why?
因为子查询的结果中有一条空值,这条空值导致主查询没有记录返回。
这是因为所有的条件和空值比较结果都是空值。因此无论什么时候只要
空值有可能成为子查询结果集合中的一部分,就不能使用NOT IN 运算符