谈谈分组: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数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

Python版本信息获取方法详解与实战

《Python版本信息获取方法详解与实战》在Python开发中,获取Python版本号是调试、兼容性检查和版本控制的重要基础操作,本文详细介绍了如何使用sys和platform模块获取Python的主... 目录1. python版本号获取基础2. 使用sys模块获取版本信息2.1 sys模块概述2.1.1

一文详解Python如何开发游戏

《一文详解Python如何开发游戏》Python是一种非常流行的编程语言,也可以用来开发游戏模组,:本文主要介绍Python如何开发游戏的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、python简介二、Python 开发 2D 游戏的优劣势优势缺点三、Python 开发 3D

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

Python版本与package版本兼容性检查方法总结

《Python版本与package版本兼容性检查方法总结》:本文主要介绍Python版本与package版本兼容性检查方法的相关资料,文中提供四种检查方法,分别是pip查询、conda管理、PyP... 目录引言为什么会出现兼容性问题方法一:用 pip 官方命令查询可用版本方法二:conda 管理包环境方法

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

基于Python开发Windows自动更新控制工具

《基于Python开发Windows自动更新控制工具》在当今数字化时代,操作系统更新已成为计算机维护的重要组成部分,本文介绍一款基于Python和PyQt5的Windows自动更新控制工具,有需要的可... 目录设计原理与技术实现系统架构概述数学建模工具界面完整代码实现技术深度分析多层级控制理论服务层控制注

mysql8.0.43使用InnoDB Cluster配置主从复制

《mysql8.0.43使用InnoDBCluster配置主从复制》本文主要介绍了mysql8.0.43使用InnoDBCluster配置主从复制,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录1、配置Hosts解析(所有服务器都要执行)2、安装mysql shell(所有服务器都要执行)3、

k8s中实现mysql主备过程详解

《k8s中实现mysql主备过程详解》文章讲解了在K8s中使用StatefulSet部署MySQL主备架构,包含NFS安装、storageClass配置、MySQL部署及同步检查步骤,确保主备数据一致... 目录一、k8s中实现mysql主备1.1 环境信息1.2 部署nfs-provisioner1.2.