MySQL_合计/统计函数

统计函数 --Count返回行的总数

sql 复制代码
#演示Mysql统计函数的使用
#统计一个班级中有多少个学生
SELECT COUNT(*) FROM student;

#统计数学成绩 > 90的学生有多少个
SELECT COUNT(*) FROM student WHERE math > 90;

#统计总分大于250的人数有多少
SELECT COUNT(*) FROM student WHERE (math + chinese + english) > 250;

count(*)和count(列)的区别:

count(*)返回满足条件的记录的总行数,count(列)统计满足条件的某列有多少个,但是会排除为null的情况

sql 复制代码
CREATE TABLE t15(`name` VARCHAR(20));
INSERT INTO t15 VALUES('tom');
INSERT INTO t15 VALUES('jack');
INSERT INTO t15 VALUES('mary');
INSERT INTO t15 VALUES(NULL);

SELECT COUNT(*) FROM t15	-- 4
SELECT COUNT(NAME) FROM t15	-- 3 排除了null的情况

合计函数 --Sum返回满足where条件的行的和,一般使用在数值列

sql 复制代码
#演示sum函数的使用
#统计一个班数学总成绩
SELECT SUM(math) FROM student;

#统计一个班语文,英语,数学各科的总成绩
SELECT SUM(chinese),SUM(math),SUM(english) FROM student;

#统计一个班级语文,英语,数学的成绩总和
SELECT SUM(chinese + math + english) FROM student;

#统计一个班级语文成绩平均分
SELECT SUM(chinese) / COUNT(*) FROM student;

注意:sum仅对数值起作用,其他类型无意义 ; 对多列求和需要加上" , "号

合计函数 --avg

sql 复制代码
#演示avg的使用
#求一个班级数学平均分
SELECT AVG(math) FROM student;
#求一个班级总分平均分
SELECT AVG(math + chinese + english) FROM student;

合计函数 --Max/min返回满足where条件的一列最大/最小值

sql 复制代码
#演示max和min的使用
#求班级最高分和最低分
SELECT MAX(math + english + chinese),MIN(math + english + chinese) FROM student;
相关推荐
小陈工1 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
0xDevNull5 小时前
MySQL数据冷热分离详解
后端·mysql
科技小花6 小时前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸6 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain6 小时前
linux个人心得22 (mysql)
数据库·mysql
阿里小阿希6 小时前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
荒川之神6 小时前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员7 小时前
MySQL安全加固十大硬核操作
数据库·mysql·安全
不吃香菜学java7 小时前
Redis简单应用
数据库·spring boot·tomcat·maven
一个天蝎座 白勺 程序猿7 小时前
Apache IoTDB(15):IoTDB查询写回(INTO子句)深度解析——从语法到实战的ETL全链路指南
数据库·apache·etl·iotdb