视频参考自:P53 - P58

https://www.bilibili.com/video/BV1xW411u7ax

什么是分组函数?

用来统计使用,其具体的实现都是基于对字段的值聚合再处理

又称为【聚合函数】或者【组函数】

聚合函数的种类:

- 1、sum 求和

- 2、avg 平均

- 3、max 最大

- 4、min 最小

- 5、count 计数记录数

单个使用

-- 演示使用
SELECT SUM(`salary`) FROM `employees`;
SELECT AVG(`salary`) FROM `employees`;
SELECT MAX(`salary`) FROM `employees`;
SELECT MIN(`salary`) FROM `employees`;
SELECT COUNT(`salary`) FROM `employees`;

组合使用

SELECT
SUM(`salary`) 工资总和,
AVG(`salary`) 平均工资,
MAX(`salary`) 最高工资,
MIN(`salary`) 最低工资,
COUNT(`salary`) 人员个数
FROM `employees`;

参数可支持的类型?

- 1、sum & avg 用于处理数值型字段

- 2、max & min & count 可处理任何类型

- 3、所有函数都会忽略NULL值,如果不希望忽略,使用IFNULL对字段处理

- 4、搭配distinct可实现去重运算

-- 返回0,0字符不支持求和&平均
SELECT SUM(`last_name`),AVG(`last_name`) FROM `employees`;
-- 时间换算成毫秒值,再进行聚合运算,返回毫秒值 【时间戳】
SELECT SUM(`hiredate`),AVG(`hiredate`) FROM `employees`; -- 可以找出最大值最小值的字符串
SELECT MAX(`last_name`),MIN(`last_name`) FROM `employees`;
-- 时间本质是毫秒值,当然也可以求值【MAX表示最新时间,MIN表示最早时间】
SELECT MAX(`hiredate`),MIN(`hiredate`) FROM `employees`; -- 计数记录数,要注意的是!不会记录NULL值
SELECT COUNT(`last_name`) FROM `employees`; -- 要实现NULL值计数,我们要对字段进行IFNULL处理,设置缺省值
SELECT COUNT(IFNULL(`commission_pct`,0)) FROM `employees`;

去重运算

-- 去重运算
SELECT SUM(DISTINCT `salary`) 去重总工资,SUM(`salary`) 非去重总工资 FROM `employees`;
SELECT COUNT(DISTINCT `salary`) 不同工资的人员个数,COUNT(`salary`) 所有人员个数 FROM `employees`;

COUNT函数的具体介绍

-- COUNT函数的详细介绍
SELECT COUNT(`salary`) FROM `employees`; -- 对单个字段计数记录数
SELECT COUNT(*) FROM `employees`; -- 对所有字段统计记录数[任意一个字段的记录为null,此函数都会忽略计数]
SELECT COUNT(1) FROM `employees`; -- [在返回的查询表中添加了一列参数的字段,并统计记录数] -- 效率问题
-- MyISAM 引擎 COUNT(*) 最高效
-- INNODB 引擎 COUNT(*) COUNT(1)的效率差不多 比COUNT(字段)效率高【因为字段需要判断NULL值】 -- 推荐使用 * 作为COUNT函数的参数计数

不要尝试分组函数和字段一并查询

-- 因为分组函数会限制字段的记录结果
SELECT AVG(`salary`),`last_name` FROM employees; -- 8版本的MySQL不再允许这样的SQL语法,直接提示语法错误
/*
错误代码: 1140
In aggregated query without GROUP BY,
expression #2 of SELECT list contains nonaggregated column 'myemployees.employees.last_name';
this is incompatible with sql_mode=only_full_group_by
*/

案例练习

-- 案例练习
-- 查询公司员工工资最大值最小值平均值求和

SELECT
MAX(`salary`) 最高工资,
MIN(`salary`) 最低工资,
AVG(`salary`) 平均工资,
SUM(`salary`) 实发合计
FROM
`employees`; -- 员工表种的最大入职时间和最小入职时间的相差天数
SELECT
MIN(`hiredate`) 最早入职时间,
MAX(`hiredate`) 最晚入职时间,
DATEDIFF(MAX(`hiredate`) , MIN(`hiredate`)) 相差天数 -- DATEDIFF()函数,求两个时间差
FROM
`employees`; SELECT DATEDIFF(NOW(),'1997-09-06'); -- 查询部门编号为90的员工个数
-- 幻想可以直接这么写... SELECT COUNT(`department_id`=90) from `employees`;
SELECT COUNT(`department_id`)
FROM `employees`
WHERE `department_id` = 90;

【DataBase】MySQL 12 SQL函数 聚合函数的更多相关文章

  1. SQL Server 聚合函数算法优化技巧

    Sql server聚合函数在实际工作中应对各种需求使用的还是很广泛的,对于聚合函数的优化自然也就成为了一个重点,一个程序优化的好不好直接决定了这个程序的声明周期.Sql server聚合函数对一组值 ...

  2. mysql数据库查询和聚合函数

    1.模糊查询 like % 表示多个任意字符 _ 表示任意一个字符 例如:查询黄姓同学 select * from student where name '黄%' select * from stud ...

  3. 数据库开发基础-SQl Server 聚合函数、数学函数、字符串函数、时间日期函数

    SQL 拥有很多可用于计数和计算的内建函数. 函数的语法 内建 SQL 函数的语法是: SELECT function(列) FROM 表 函数的类型 在 SQL 中,基本的函数类型和种类有若干种.函 ...

  4. MySQL实现SQL Server排名函数

    最近在MySQL中遇到分组排序查询时,突然发现MySQL中没有row_number() over(partition by colname)这样的分组排序.并且由于MySQL中没有类似于SQL Ser ...

  5. SQL Server聚合函数

    聚合函数对一组值计算后返回单个值.除了count(统计项数)函数以外,其他的聚合函数在计算式都会忽略空值(null).所有的聚合函数均为确定性函数.即任何时候使用一组相同的输入值调用聚合函数执行后的返 ...

  6. MySQL最常用分组聚合函数

    一.聚合函数(aggregation function)---也就是组函数 在一个行的集合(一组行)上进行操作,对每个组给一个结果. 常用的组函数: AVG([distinct] expr) 求平均值 ...

  7. MySql 学习之路-聚合函数

    下面是mysql 数据库中经常用到的聚合函数的简单实例 -- 创建学生表 create table student ( id int primary key auto_increment commen ...

  8. (2.17)Mysql之SQL基础——日期函数

    关键词:mysql时间函数,mysql日期函数 [1]curdate():返回当前日期(2019-03-06),curdate()+0 返回(20190306) [2]curtime():返回当前时间 ...

  9. 深入学习之mysql(四)聚合函数

    聚合函数:COUNT统计记录的条数.SUM求和函数.AVG求平均值.MAX求最大值.MIN求最小值   一.COUNT练习: 1.统计学校一共有多少个学生: mysql> SELECT COUN ...

  10. PCB MS SQL CLR聚合函数(函数作用,调用顺序,调用次数) CLR说明

    用CLR写函数:标量函数,表值函数 很好理解,如果用聚合函数则不是那么好理解了, 这里将CLR函数说明一下,其实关键是对聚合函数说明 用CLR写聚合函数关键点,是要理解CLR与SQL是如何进行数据交互 ...

随机推荐

  1. 前端性能优化的利器 ——— 浅谈JavaScript中的防抖和节流

    防抖和节流函数是工作中两种常用的前端性能优化函数,今天我就来总结一下什么是防抖和节流,并详细说明一下如何在工作中应用防抖和节流函数 什么是防抖和节流? 在 JavaScript 中,防抖(deboun ...

  2. echarts做折线图

    先给大家看图 父组件      <el-container v-show="abscissa">         <lineEchart           :C ...

  3. 华擎B365M ITX ,SSD WIN7 电脑卡顿,4K异常,9代 I7

    华擎B365M ITX ,SSD WIN7 电脑卡顿,4K异常,9代 I7 故障现象: 新装的电脑,WIN7 电脑卡顿. 表现:我的电脑打开很慢,延时个1-3秒左右.任务管理器打开很慢,N秒. 换了块 ...

  4. PMP 变更专题

    在浏览器Console中输入下列对应命令 document.getElementsByTagName('video')[0].requestPictureInPicture()--进入画中画 docu ...

  5. 燕千云ITAM:解锁数字化时代下企业竞争新优势

    数字化时代下,企业的IT资产管理(ITAM)尤为关键.企业通过在成长的每个阶段实施有效的IT资产管理策略,以确保资源的最优化利用和风险的有效控制,并在竞争激烈的市场环境中保持优势.然而实际实践中,企业 ...

  6. 报错解决 :Resolved [org.springframework.web.bind.MissingServletRequestParameterException

    报错解决 :Resolved [org.springframework.web.bind.MissingServletRequestParameterException 解决方法:RequestPar ...

  7. Filter过滤器进行统一参数处理demo

    Filter过滤器进行统一参数处理demo import org.slf4j.Logger; import org.slf4j.LoggerFactory; import javax.servlet. ...

  8. 百度地图API 循环添加信息窗口问题

    百度地图API循环添加信息窗口,会出现所有消息只显示在第一个窗口的位置的问题.并且信息内容相同 解决方法1 转载自 https://blog.csdn.net/zz_mm/article/detail ...

  9. Linux下Oracle11G数据备份恢复(RMAN)

    数据库安装参考步骤1--14 https://www.cnblogs.com/baixisuozai/p/17852235.html #rman数据库备份脚本 #!/bin/bash PATH=$PA ...

  10. 用Tensorboard在VScode Remote ssh中显示图像

    可以用Tensorboard在vscode的ssh连接中显示plot出的图像. 具体方法如下: from torch.utils.tensorboard import SummaryWriter wr ...