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
相关推荐
炸炸鱼.3 分钟前
MySQL 故障排查与生产环境优化(精简实用版)
数据库·mysql·adb
**蓝桉**3 分钟前
MongoDB入门
数据库·mongodb
ZHANG13HAO7 分钟前
嵌入式温度记录仪:15 天数据存储与 BLE 无损压缩方案(CH592 最优实现)
大数据·服务器·数据库
mcooiedo12 分钟前
ORM框架详解:为什么不直接写SQL?
数据库·sql
攒了一袋星辰21 分钟前
SequenceGenerator废弃序列号异步补偿机制技术实现方案
java·开发语言·数据库·mysql
熬夜的咕噜猫28 分钟前
MySQL 故障排查与优化
大数据·运维·服务器·mysql
刘晨鑫132 分钟前
MySQL故障排查与生产环境优化
数据库·mysql·adb
PD我是你的真爱粉1 小时前
MySQL 锁机制:从理论分类到死锁实战
数据库·mysql·adb
Benszen1 小时前
SQL 基础及 MySQL DBA 运维实战 - 6:Mycat代理技术
sql·mysql·dba
会飞的大可1 小时前
Redis 故障排查与应急手册:从理论到实践
数据库·redis·缓存