谈谈分组:sql的group by+聚集函数 和 python的groupby+agg

2024-09-04 07:18

本文主要是介绍谈谈分组:sql的group by+聚集函数 和 python的groupby+agg,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

直接举例子+分析例子+总结来说,我先给几个表:

学生表:student(学号,姓名,年龄,院系);
课程表:course(课程号,课程名,学分);
学生选课表:sc(学号,课程号,分数);

啥时候用分组呢?

我由简至深来谈。
1、比如让我们查询各个课程号及相应的选课人数。
首先定位到sc表上,“各个”很明显就是要按课程分组,group by出场了,分组后对每组去统计选课人数,聚集函数出场了。
聚集函数就是一些统计指标:求和最大值最小值均值方差count这些。

select 课程号,count(distinct 学号)
from  sc
group by 课程号;

2、 比如查询选修了3门以上课程的学生学号。
首先我们知道是定位到sc表上,再细读一遍这句话,是选了3门以上课程的学生,那么我们是不是要知道每一个学生选了几门呢。当我们分析出了 “每个”“各个”“每天”等 这样的字眼时,就知道要分组了,这时候group by就出场了。我们要先根据学生分组,分好后要去对每组做一个统计,统计什么,统计每组有多少课程(即每个学号下有几门课),然后过滤掉不满足统计值的组,这就要用到having子句和聚集函数了。

select 学号
from sc
order by 课程号
having count(*)>3;

3、比如查询平均成绩大于等于90分的学生学号和平均成绩。
平均成绩,知道了要用到聚集函数avg()。再细读这不是整体的平均成绩,而是每个学生的平均成绩,知道了要用分组group by。分组后,各组以一个学生为单位。大于90分的学生,知道了要过滤掉小于90分的分组,having也出场了。梳理一下,就是先要分组,分组后,对每组的成绩那列做一个avg的统计,最后用having+avg做一个过滤不合格分组。

select 学号,avg(grade) --select这里返回的avg是统计指标满足>=90的分组的
from sc
group by 学号
having avg(成绩)>=90; 

总结一下grouyp by

简单来说,就是用来分组的,同时对每个组做一些统计(聚集函数)。
细说:
group by 是这样用的。它是和聚集函数一起的。如果我们要统计每组的统计特征(求和最大最小均值方差count),我们可以用group by,再在select里面去统计。如果我们要根据每组的统计特征去筛掉一些组,我们可以用group by,再在having里面去根据统计特征的值过滤掉一些组。

python待补充
对应到python里就是表名.group by([列名]).agg(列名:聚集函数)。

这篇关于谈谈分组:sql的group by+聚集函数 和 python的groupby+agg的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1135361

相关文章

MySQL中时区参数time_zone解读

《MySQL中时区参数time_zone解读》MySQL时区参数time_zone用于控制系统函数和字段的DEFAULTCURRENT_TIMESTAMP属性,修改时区可能会影响timestamp类型... 目录前言1.时区参数影响2.如何设置3.字段类型选择总结前言mysql 时区参数 time_zon

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

利用Python编写一个简单的聊天机器人

《利用Python编写一个简单的聊天机器人》这篇文章主要为大家详细介绍了如何利用Python编写一个简单的聊天机器人,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 使用 python 编写一个简单的聊天机器人可以从最基础的逻辑开始,然后逐步加入更复杂的功能。这里我们将先实现一个简单的

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

Python实现高效地读写大型文件

《Python实现高效地读写大型文件》Python如何读写的是大型文件,有没有什么方法来提高效率呢,这篇文章就来和大家聊聊如何在Python中高效地读写大型文件,需要的可以了解下... 目录一、逐行读取大型文件二、分块读取大型文件三、使用 mmap 模块进行内存映射文件操作(适用于大文件)四、使用 pand

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一

Python xmltodict实现简化XML数据处理

《Pythonxmltodict实现简化XML数据处理》Python社区为提供了xmltodict库,它专为简化XML与Python数据结构的转换而设计,本文主要来为大家介绍一下如何使用xmltod... 目录一、引言二、XMLtodict介绍设计理念适用场景三、功能参数与属性1、parse函数2、unpa

Python中使用defaultdict和Counter的方法

《Python中使用defaultdict和Counter的方法》本文深入探讨了Python中的两个强大工具——defaultdict和Counter,并详细介绍了它们的工作原理、应用场景以及在实际编... 目录引言defaultdict的深入应用什么是defaultdictdefaultdict的工作原理

Python中@classmethod和@staticmethod的区别

《Python中@classmethod和@staticmethod的区别》本文主要介绍了Python中@classmethod和@staticmethod的区别,文中通过示例代码介绍的非常详细,对大... 目录1.@classmethod2.@staticmethod3.例子1.@classmethod