软件测试|MySQL中的GROUP BY分组查询,你会了吗?

news2024/11/17 11:44:59

MySQL中的GROUP BY分组查询:详解与示例

在MySQL数据库中,GROUP BY语句用于将数据按照指定的列进行分组,并对每个分组执行聚合函数操作。这就是的我们可以在查询中汇总数据并生成有意义的结果。本文将深入介绍MySQL中的GROUP BY语句,并提供示例来说明其用法。

基本语法

在 MySQL 中,GROUP BY 关键字可以根据一个或多个字段对查询结果进行分组。

使用 GROUP BY 关键字的语法格式如下:

SELECT 列1, 列2, 聚合函数(列3)
FROM 表名
GROUP BY 列1, 列2;

在上述语法中,我们需要指定要选择的列(除了聚合函数所用的列)。然后使用GROUP BY将结果按照指定的列进行分组。最后,您可以使用聚合函数(如SUM、COUNT、AVG等)对每个分组进行操作。

使用示例

  1. 订单总额按客户分组

假设我们有一个订单表orders,包含customer_idorder_dateorder_amount等列。我们想要按照客户分组,计算每个客户的订单总额,语句如下:

SELECT customer_id, SUM(order_amount) AS total_amount
FROM orders
GROUP BY customer_id;

在上述查询中,我们选择了customer_id列,并使用SUM()函数计算每个客户的订单总额。然后使用GROUP BY将结果按照customer_id分组。

  1. 按月份统计销售数量

假设我们有一个销售表sales,包含sale_datequantity列。我们想要按照每个月份统计销售的总数量,语句如下:

SELECT DATE_FORMAT(sale_date, '%Y-%m') AS month, SUM(quantity) AS total_quantity
FROM sales
GROUP BY month;

在上述查询中,我们使用DATE_FORMAT()函数将sale_date格式化为%Y-%m的形式,以表示年份和月份。然后使用SUM()函数计算每个月份的销售总数量,并通过GROUP BY按照month进行分组。

  1. 多列分组

我们还可以同时按照多列进行分组。假设我们有一个员工表employees,包含departmentgender列。我们想要按照部门和性别统计员工数量,语句如下:

SELECT department, gender, COUNT(*) AS employee_count
FROM employees
GROUP BY department, gender;

在上述查询中,我们选择了departmentgender列,并使用COUNT()函数计算每个部门和性别组合的员工数量。然后使用GROUP BY将结果按照这两列进行分组。

  1. 筛选特定分组

有时候,我们可能只想要对满足特定条件的分组执行聚合操作。假设我们有一个学生表students,包含major和gpa列。我们想要统计每个专业中平均GPA大于3.5的学生数量,语句如下:

SELECT major, AVG(gpa) AS avg_gpa, COUNT(*) AS student_count
FROM students
GROUP BY major
HAVING avg_gpa > 3.5;

在上述查询中,我们使用AVG()函数计算每个专业的平均GPA,并使用COUNT()函数计算每个专业的学生数量。然后使用GROUP BY将结果按照major分组。最后,我们使用HAVING子句筛选出平均GPA大于3.5的专业。

总结

MySQL中的GROUP BY语句允许我们对数据进行分组,并在每个分组上执行聚合操作。通过合理使用GROUP BY,我们可以从大量数据中提取有意义的信息,以满足各种分析和报告需求。在实际使用中,我们需要注意合理选择聚合函数和分组列,以获得所需的统计结果。

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你! 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1372014.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Java中多线程二

抢占调度模型 概述:优先让优先级高的线程使用 CPU ,如果线程的优先级相同,那么随机会选择一个,优先级高的线程获取的 CPU 时间片相对多一些 Thread 类中一些关于线程的方法 方法简述public final int getPriority()返回此线程的优…

【博士每天一篇文-算法】Graph Structure of Neural Networks

阅读时间:2023-11-12 1 介绍 年份:2020 作者:尤家轩 斯坦福大学 期刊: International Conference on Machine Learning. 引用量:130 论文探讨了神经网络的图结构与其预测性能之间的关系。作者提出了一种新的基于图的…

UGUI Image图像控件替换图片

代码为探索而来,不是最优代码,请按需使用。 Unity3d引擎版本:Uinty3d 20233.2.3f1 补充一下图片如何改成Texture2D: 1、将图片导入unity。 2、选择图片,按下图操作,点击应用即可。 脚本代码&#xff1a…

【算法每日一练]-dfs (保姆级教程 篇9) #俄罗斯方块 #ABC Puzzle #lnc的工资

目录 今日知识点: 二维图形的状态压缩,存下所有的合法状态然后暴力遍历 dfs的优化剪枝 二项式定理 俄罗斯方块 ABC Puzzle lnc的工资 俄罗斯方块 322D 题意:在4*4方格中分别给出3个俄罗斯方块,问是否可以经过旋转&#xf…

电脑提示找不到msvcr100.dll的解决方法分享,只需四步即可搞定

“找不到msvcr100.dll”是一个常见的问题,许多人在使用计算机时都可能遇到过。这个文件是Microsoft Visual C 2010 Redistributable Package的一部分,包含了许多C运行库函数的实现。当我们在使用一些软件或游戏时,这些程序会调用msvcr100.dll…

鱼哥赠书活动第⑥期:《内网渗透实战攻略》看完这本书教你玩转内网渗透测试成为实战高手!!!!

鱼哥赠书活动第⑥期:《内网渗透实战攻略》 如何阅读本书:本书章节介绍:本书大致目录:适合阅读对象:赠书抽奖规则:往期赠书福利: 当今,网络系统面临着越来越严峻的安全挑战。在众多的安全挑战中&…

统计学-R语言-1

文章目录 统计学介绍基本类型数据和变量数据抽样总结 统计学介绍 统计学(statistics)是“数据的科学” 1.是用以收集数据、分析数据和由数据得出结论的一组概念、原则和方法。 2.统计学进行推断的基础是数据(data)。数据不仅仅限于数字,也可能是图表、视频、音频或…

OpenHarmony—编译构建指导

概述 OpenHarmony编译子系统是以GN和Ninja构建为基座,对构建和配置粒度进行部件化抽象、对内建模块进行功能增强、对业务模块进行功能扩展的系统,该系统提供以下基本功能: 以部件为最小粒度拼装产品和独立编译。支持轻量、小型、标准三种系…

DHSP和DNS

一、服务程序 1.1DHCP定义 DHCP(动态主机配置协议)是一个局域网的网络协议。指的是由服务器控制一段IP地址范围,客户机登录服务器时就可以自动获得服务器分配的IP地址和子网掩码。默认情况下,DHCP作为Windows Server的一个服务组…

第三次面试总结 - 吉云集团 - 全栈开发

🧸欢迎来到dream_ready的博客,📜相信您对专栏 “本人真实面经” 很感兴趣o (ˉ▽ˉ;) 专栏 —— 本人真实面经,更多真实面试经验,中大厂面试总结等您挖掘 目录 总结(非详细) 面试内…

【办公技巧】Word中如何对齐选择题中的ABCD选项?

使用word文件制作试卷,如何将ABCD选项全部设置对齐?除了一直按空格或者Tab键以外,还有其他方法吗?今天分享如何将ABCD选项对齐。 首先,我们打开【替换和查找】,在查找内容输入空格,然后点击全部…

mysql之数据类型、建表以及约束

文章目录 一、CRUD1.1 SELECT(查询)1.1.1概念1.1.2语法(这里的都改为<>)1.1.3含义(这里的都改为<>) 1.2 INSERT(新增)1.2.1概念1.2.2语法1.2.3含义1.2.4 由INSERT 语句的两种形式可以看出: 1.3UPDATE(修改)1.3.1语法1.3.2含义 1.4DELETE(删除)1.4.1语法1.4.2含义 二…

Aop编程之动态代理

1、Java代理介绍 Java中的代理方式包括静态代理和动态代理。 静态代理在编译期间就确定了代理对象&#xff0c;动态代理是在运行期间动态生成代理对象。动态代理包括cglib动态代理和jdk动态代理&#xff0c;在目标对象有接口的情况下&#xff0c;可以使用jdk动态代理或者cglib…

PyTorch项目源码学习(2)——Tensor代码结构初步学习

PyTorch版本&#xff1a;1.10.0 Tensor Tensor是Pytorch项目较为重要的一部分&#xff0c;其中的主要功能如存储&#xff0c;运算由C和CUDA实现&#xff0c;本文主要从前端开始探索学习Tensor的代码结构。 结构探索 PyTorch前端位于torch目录下&#xff0c;从_tensor.py可以…

手持终端PDA定制厂家_5G安卓手持机设备/条形码扫描手持机PDA

手持终端PDA是一种功能强大的手持终端设备&#xff0c;具备一维码和二维码扫描功能&#xff0c;广泛应用于门票管理、零售、智能巡检、仓储物资管理、金融、快递等领域。 这款手持终端基于MT6877方案&#xff0c;搭载八核处理器(2xCortex-A78 2.4GHz 6xCortex-A55 2.0GHz)&…

【机器学习前置知识】狄利克雷分布

在阅读本文前&#xff0c;建议先食用以下几篇文章以能更好地理解狄利克雷分布&#xff1a; 二项分布 Beta分布 多项分布 共轭分布 狄利克雷分布 狄利克雷分布(Dirichlet distribution)是Beta分布的扩展&#xff0c;把Beta分布从二元扩展到多元形式就是狄利克雷分布&#…

【PixPin】比Snipaste、QQ的截图长图和动图还好用的截图工具

1.下载地址—— 下载地址 2.下载压缩包 双击exe文件运行 按默认的来 中文安装 选择安装路径 下一步&#xff0c;安装 安装完成&#xff0c;可以自己设置快捷键

使用Django框架自带的Form表单完成简单的用户登录注册

如果不知道怎么配置Django环境以及如何连接数据库请点击我的上一篇博客&#xff1a; 使用pycharm初始化Django框架并连接Sql Server 文章目录 1.Django默认生成的数据表2.用户登录2.1创建登录页面2.2视图处理登录请求2.3配置访问路径 3.用户注册3.1创建用户表单3.2创建注册模版…

VScode代码格式化

Vscode代码格式化 有时候总是想,为什么我的代码格式化完后为什么这么挤,而且不想让代码在格式化后换行,他总是自动换行,所以我去网上查了相关资料 第一步,搜索插件ESLint并安装,安装完成后你就可以进行格式化了 第二步,设置中选择settings,搜索Tab size,根据一下图片更改 第…

全志T113开发板Qt远程调试

1引言 通常情况下工程师在调试Qt程序时&#xff0c;需要频繁制作镜像烧录到核心板来测试Qt程序是否完善&#xff0c;这样的操作既费时又费力。这时我们可以通过QtCreator设备功能&#xff0c;定义设备后&#xff0c;在x86_64虚拟机上交叉编译qt程序&#xff0c;将程序远程部署到…