当前位置: 首页 > news >正文

10. Mysql 分组或汇总查询

Mysql 函数参考和扩展:Mysql 常用函数和基础查询、 Mysql 官网

Mysql 语法执行顺序如下,一定要清楚!!!运算符相关,可前往 Mysql 基础语法和执行顺序扩展。

(8) select (9) distinct (11)<columns_name list>
(1) from <left_table>
(3) <join_type> join <right_table>
(2) on <join_condition>
(4) where <where_condition>
(5) group by <group_by columns_name list>
(6) with <rollup>
(7) having <having_condition>
(10) order by <order_by columns_name list>
(12) limit <[offset] rows>
;

1. 数据准备

这里有一张一年级一班的成绩得分表。

create table sql_test1.student_subject_scroe
(student_id varchar(255) comment '学生编号',subject    varchar(255) comment '课程名称',score      int comment '分数'
);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('01', 'english', 89);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('01', 'math', null);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('01', 'china', 97);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('02', 'english', 87);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('02', 'math', 53);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('02', 'china', 96);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('03', 'english', 87);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('03', 'math', 53);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('03', 'china', 96);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('04', 'english', 84);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('04', 'math', 52);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('04', 'china', 96);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('05', 'english', 74);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('05', 'math', 47);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('05', 'china', 92);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('06', 'english', 73);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('06', 'math', 40);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('06', 'china', 90);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('07', 'english', 73);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('07', 'math', 40);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('07', 'china', 90);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('08', 'english', 73);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('08', 'math', 40);
insert into sql_test1.student_subject_scroe (student_id, subject, score) values ('08', 'china', 90);

2. 汇总查询

输入的是一组数据的集合,输出的是单个值。

常用的聚合函数如下:

  • count([distinct] expr):返回expr的记录数。
  • sum(expr):返回expr的汇总值。
  • avg(expr):返回expr的平均值。
  • std(expr):返回expr的标准差。
  • max(expr):返回expr的最大值。
  • min(expr):返回expr的最小值。
  • group_concat([distinct] expr …):返回一串字符串。

统计表数据总量、学生数、有效数据数量和考试科目。

# 统计一年级一班成绩得分表,总记录数、学生人数、有效得分记录数和考试科目
select count(*)                                                      total_records,count(distinct student_id)                                    s_cnt,count(score)                                                  valid_cnt,group_concat(distinct subject order by subject separator '、') subjects
from sql_test1.student_subject_scroe;
+---------------+-------+-----------+------------------------+
| total_records | s_cnt | valid_cnt | subjects               |
+---------------+-------+-----------+------------------------+
|            24 |     8 |        23 | china、english、math   |
+---------------+-------+-----------+------------------------+
  • count(*):返回表中数据总量;
  • count(1):与COUNT(*)效果相同,因为它只是在每一行中都返回一个非空的值;
  • count(字段):返回字段非空值的行数;

count(*)会统计值为 NULL 的行,而count(字段)不会统计此列为 NULL 值的行。

执行效率顺序:count(*)=count(1) >count(字段)

只适用于数值类型的函数有:avg()、sum()、std();

# 查看一年级一班语文平均分,avg = sum/count
select avg(score)                              china_avg_score,sum(score) / count(distinct student_id) china_avg_score2,std(score)                              std_score
from sql_test1.student_subject_scroe
where subject = 'china';
+-----------------+------------------+--------------------+
| china_avg_score | china_avg_score2 | std_score          |
+-----------------+------------------+--------------------+
|         93.3750 |          93.3750 | 2.9553976043842236 |
+-----------------+------------------+--------------------+

3. 分组查询

SELECT中出现的非汇总聚合的字段必须声明在GROUP BY 中。

查看一年级一班各学科数据详情。

select subject,count(score)                                          valid_cnt,avg(score)                                            avg_score,sum(score) / count(score)                             avg_score2,std(score)                                            std_score,min(score)                                            min_score,max(score)                                            max_score,group_concat(score order by score desc separator '、') score_str
from sql_test1.student_subject_scroe
group by subject;
+---------+-----------+-----------+------------+--------------------+-----------+-----------+---------------------------------------+
| subject | valid_cnt | avg_score | avg_score2 | std_score          | min_score | max_score | score_str                             |
+---------+-----------+-----------+------------+--------------------+-----------+-----------+---------------------------------------+
| china   |         8 |   93.3750 |    93.3750 | 2.9553976043842236 |        90 |        97 | 9796969692909090        |
| english |         8 |   80.0000 |    80.0000 | 6.8738635424337655 |        73 |        89 | 8987878474737373        |
| math    |         7 |   46.4286 |    46.4286 |  5.876275371772324 |        40 |        53 | 53535247404040            |
+---------+-----------+-----------+------------+--------------------+-----------+-----------+---------------------------------------+

查看一年级一班学科平均分低于60的学科数据详情

select subject,count(score)                                          valid_cnt,avg(score)                                            avg_score,sum(score) / count(score)                             avg_score2,std(score)                                            std_score,min(score)                                            min_score,max(score)                                            max_score,group_concat(score order by score desc separator '、') score_str
from sql_test1.student_subject_scroe
where score is not null
group by subject
having avg(score) < 60;
+---------+-----------+-----------+------------+-------------------+-----------+-----------+----------------------------------+
| subject | valid_cnt | avg_score | avg_score2 | std_score         | min_score | max_score | score_str                        |
+---------+-----------+-----------+------------+-------------------+-----------+-----------+----------------------------------+
| math    |         7 |   46.4286 |    46.4286 | 5.876275371772324 |        40 |        53 | 53535247404040       |
+---------+-----------+-----------+------------+-------------------+-----------+-----------+----------------------------------+

WHEREHAVING的区别:

  • WHERE用于在执行查询之前对行进行筛选,而HAVING用于对查询结果进行分组后的筛选。
  • WHERE可以应用于单个表或多个表的连接查询,而HAVING必须与GROUP BY一起使用。
  • WHERE可以使用各种条件表达式进行筛选,而HAVING可以使用聚合函数和条件表达式对分组后的结果进行筛选。

相关文章:

  • 【Linux小项目】实现自己的bash
  • Python语言创建爬虫代理IP池详细步骤和代码示例
  • Mysql使用周期性计划任务定时备份,发现备份的文件都是空的?为什么?如何解决?
  • 基于SWT的图书管理系统设计
  • Android之高级UI
  • 代码块01-Java
  • MySQL递归查询:洞悉数据的层层关联
  • flutter编译和构建鸿蒙应用程序(windows环境)
  • 卸载软件最最最彻底的工具——Uninstall Tool
  • 项目启动出现白屏问题需要刷新后才能显示解决方案
  • 通付盾Web3专题 | SharkTeam:起底朝鲜APT组织Lazarus Group,攻击手法及洗钱模式
  • 代码随想录算法训练营第五十三天|1143. 最长公共子序列、1035.不相交的线、53.最大子数组和
  • 实用高效 无人机光伏巡检系统助力电站可持续发展
  • 【代码随想录刷题】Day18 二叉树05
  • 【开源】基于Vue和SpringBoot的食品生产管理系统
  • [js高手之路]搞清楚面向对象,必须要理解对象在创建过程中的内存表示
  • 《Java8实战》-第四章读书笔记(引入流Stream)
  • Angular 响应式表单之下拉框
  • CentOS 7 防火墙操作
  • CSS进阶篇--用CSS开启硬件加速来提高网站性能
  • Gradle 5.0 正式版发布
  • JS基础之数据类型、对象、原型、原型链、继承
  • Linux链接文件
  • Octave 入门
  • Python语法速览与机器学习开发环境搭建
  • 官方新出的 Kotlin 扩展库 KTX,到底帮你干了什么?
  • 函数式编程与面向对象编程[4]:Scala的类型关联Type Alias
  • 前端技术周刊 2019-01-14:客户端存储
  • 如何设计一个比特币钱包服务
  • 体验javascript之美-第五课 匿名函数自执行和闭包是一回事儿吗?
  • 我有几个粽子,和一个故事
  • 延迟脚本的方式
  • !! 2.对十份论文和报告中的关于OpenCV和Android NDK开发的总结
  • (附源码)spring boot公选课在线选课系统 毕业设计 142011
  • (附源码)springboot工单管理系统 毕业设计 964158
  • (十一)c52学习之旅-动态数码管
  • (完整代码)R语言中利用SVM-RFE机器学习算法筛选关键因子
  • (一)Thymeleaf用法——Thymeleaf简介
  • (转)linux自定义开机启动服务和chkconfig使用方法
  • ***linux下安装xampp,XAMPP目录结构(阿里云安装xampp)
  • .net core控制台应用程序初识
  • .net framework profiles /.net framework 配置
  • .NET分布式缓存Memcached从入门到实战
  • .net实现客户区延伸至至非客户区
  • .sh文件怎么运行_创建优化的Go镜像文件以及踩过的坑
  • [2015][note]基于薄向列液晶层的可调谐THz fishnet超材料快速开关——
  • [23] GaussianAvatars: Photorealistic Head Avatars with Rigged 3D Gaussians
  • [C#]winform制作圆形进度条好用的圆环圆形进度条控件和使用方法
  • [C++] Windows中字符串函数的种类
  • [C++] 默认构造函数、参数化构造函数、拷贝构造函数、移动构造函数及其使用案例
  • [codevs 1296] 营业额统计
  • [Docker]五.Docker中Dockerfile详解
  • [Gamma]阶段测试报告
  • [GYCTF2020]Ez_Express
  • [JavaWeb学习] Spring Ioc和DI概念思想