MySQL——高级查询(1)聚合函数

实际开发中,经常需要对某些数据进行统计,例如统计某个字段的最大值、最小值平均值等,为此,MySQL中提供了一些函数来实现这些功能,具体如下表所示。

|-------------|----------|
| 函数名称 | 作用 |
| COUNTOSUM() | 返回某列的行数 |
| SUM() | 返回某列值的和 |
| AVG() | 返回某列的平均值 |
| MAX() | 返回某列的最大值 |
| MIN() | 返回某列的最小值 |

表中的函数用于对一组值进行统计,并返回唯一值,这些函数被称为聚合函数,下面就对聚合函数的用法进行讲解。

1.COUNT()函数

COUNT()函数用来统计记录的条数,其语法格式如下所示:

sql 复制代码
SELECT COUNT(*) FROM 表名

使用上面的语法格式可以求出表中有多少条记录。

例如,查询 student 表中一共有多少条记录,SQL语句如下所示:

sql 复制代码
SELECT COUNT(*) FROM student;

执行结果如下所示:

sql 复制代码
mysql> SELECT COUNT(*) FROM student;
+----------+
| COUNT(*) |
+----------+
|        8 |
+----------+
1 row in set (0.01 sec)

从查询结果可以看出,student表中一共有8条记录

2.SUM()函数

SUM()是求和函数,用于求出表中某个字段所有值的总和,其语法格式如下:

sql 复制代码
SELECT SUM(字段名) FROM 表名;

使用上面的语句可以求出指定字段值的总和。

例如,求出 student 表中 grade字段的总和,SQL 语句如下所示:

sql 复制代码
SELECT SUM(grade) FROM student;

执行结果如下所示:

sql 复制代码
mysql> SELECT SUM(grade) FROM student;
+------------+
| SUM(grade) |
+------------+
|        652 |
+------------+
1 row in set (0.01 sec)

从查询结果可以看到,所有学生 grade 字段的总和为 652。

3.AVG()函数

AVG()函数用于求出某个字段所有值的平均值,其语法格式如下所示:

sql 复制代码
SELECT AVG(字段名) FROM student;

使用上面的语句可以求出指定字段所有值的平均值。

例如,求出 student 表中 grade 字段的平均值,SQL语句如下所示:

sql 复制代码
SELECT AVG(grade) FROM student;

执行结果如下所示:

sql 复制代码
mysql> SELECT AVG(grade) FROM student;
+------------+
| AVG(grade) |
+------------+
|       76.7 |
+------------+
1 row in set (0.00 sec)

从查询结果可以看到,所有学生 grade 字段的平均值为 81.5。

4. MAX()函数

MAX()函数是求最大值的函数,用于求出某个字段的最大值,其语法格式如下所示:

sql 复制代码
SELECT MAX(grade) FROM student;

例如,求出 student 表中所有学生 grade字段的最大值,SQL 语句如下所示:

sql 复制代码
mysql> SELECT MAX(grade) FROM student;
+------------+
| MAX(grade) |
+------------+
|        100 |
+------------+
1 row in set (0.01 sec)

从查询结果可以看到,所有学生 grade 字段的最大值为 100。

5.MIN()函数

MIN()函数是求最小值的函数,用于求出某个字段的最小值,其语法格式如下所示:

sql 复制代码
SELECT MIN(grade) FRoM student;

例如,求出 student 表中 grade 字段的最小值,SQL 语句如下所示:

sql 复制代码
mysql> SELECT MIN(grade) FRoM student;
+------------+
| MIN(grade) |
+------------+
|         40 |
+------------+
1 row in set (0.00 sec)

从查询结果可以看到,所有学生 grade 字段的最小值为 40。

相关推荐
程序员岳焱20 分钟前
Java 与 MySQL 性能优化:Java 实现百万数据分批次插入的最佳实践
后端·mysql·性能优化
计算机毕设定制辅导-无忧学长44 分钟前
西门子 PLC 与 Modbus 集成:S7-1500 RTU/TCP 配置指南(一)
服务器·数据库·tcp/ip
程序员柳1 小时前
基于微信小程序的校园二手交易平台、微信小程序校园二手商城源代码+数据库+使用说明,layui+微信小程序+Spring Boot
数据库·微信小程序·layui
梦在深巷、2 小时前
MySQL/MariaDB数据库主从复制之基于二进制日志的方式
linux·数据库·mysql·mariadb
IT乌鸦坐飞机2 小时前
ansible部署数据库服务随机启动并创建用户和设置用户有完全权限
数据库·ansible·centos7
IT_10242 小时前
Spring Boot项目开发实战销售管理系统——数据库设计!
java·开发语言·数据库·spring boot·后端·oracle
Johny_Zhao2 小时前
Ubuntu系统安装部署Pandawiki智能知识库
linux·mysql·网络安全·信息安全·云计算·shell·yum源·系统运维·itsm·pandawiki
祁思妙想3 小时前
八股学习(三)---MySQL
数据库·学习·mysql
惊骇世俗王某人3 小时前
1.MySQL之如何定位慢查询
数据库·mysql
秦歌6664 小时前
向量数据库-Milvus快速入门
数据库·milvus