MySQL——聚合函数及分组过滤

聚合函数(常用)

|----------|--------|
| 函数名称 | 描述 |
| COUNT() | 计数 |
| SUM() | 求和 |
| AVG() | 平均值 |
| MAX() | 最大值 |
| MIN() | 最小值 |
| ... | ... |

sql 复制代码
-- 都能够统计表中的数据(查询表中有多少个记录)
SELECT COUNT(studentname) FROM student  -- COUNT(字段),会忽略所有的NULL值 
SELECT COUNT(*) FROM student  -- COUNT(*) ,不会忽略NULL值,本质是计算行数
SELECT COUNT(1) FROM result  -- COUNT(1),不会忽略NULL值

SELECT sum(studentresult) AS 总和 FROM result
SELECT avg(studentresult) AS 平均分 FROM result
SELECT max(studentresult) AS 最高分 FROM result
SELECT min(studentresult) AS 最低分 FROM result

分组和过滤

sql 复制代码
-- 查询不同科目的平均分,最高分和最低分,平均分大于80
-- 核心:(根据不同的课程分组)
SELECT subjectname,AVG(studentresult) AS 平均分,MAX(studentresult) AS 最高分,MIN(studentresult) AS 最低分
FROM result r
INNER JOIN `subject` sub
ON r.`subjectno` = sub.`subjectno`
GROUP BY r.`subjectno`  -- 通过什么字段来分组
HAVING 平均分>80
相关推荐
霑潇雨几秒前
题解 | 深入分析各款产品年总销售额与竞品的年度对比
大数据·开发语言·数据库
scofield_gyb16 分钟前
Redis 6.2.7安装配置
前端·数据库·redis
qiumingxun17 分钟前
Redis——使用 python 操作 redis 之从 hmse 迁移到 hset
数据库·redis·python
2401_8735449231 分钟前
使用XGBoost赢得Kaggle比赛
jvm·数据库·python
ruxingli32 分钟前
MySQL优化
数据库·mysql
m0_5698814734 分钟前
进阶技巧与底层原理
jvm·数据库·python
feng68_39 分钟前
MySQL集群主从复制
linux·运维·数据库·mysql·adb
RDCJM1 小时前
redis 使用
数据库·redis·缓存
万岳科技系统开发1 小时前
教育培训系统开发正在重构培训机构的盈利结构
数据库·重构
2501_945423541 小时前
数据分析师的Python工具箱
jvm·数据库·python