软件测试|弄懂GROUP BY看这一篇文章就够了

简介

在SQL(结构化查询语言)中,GROUP BY子句是一个强大的工具,用于对查询结果进行分组和聚合操作。通过使用GROUP BY子句,可以根据指定的列或表达式对数据进行分组,并对每个分组应用聚合函数,从而得到更有意义的查询结果。本文将深入介绍SQL中的GROUP BY子句,包括其语法、用途以及示例。

GROUP BY 语法

GROUP BY 子句的基本语法如下:

SELECT column1, column2
FROM table_name
WHERE [ conditions ]
GROUP BY column1, column2
ORDER BY column1, column2

使用说明:

  • GROUP BY 子句需要和 SELECT 语句一起使用
  • 如果有 WHERE 子句,那么 WHERE 子句需要放在 GROUP BY 子句之前
  • 如果有 ORDER BY 子句,那么 ORDER BY 子句需要放在 GROUP 子句之后

主要用途:

GROUP BY子句主要用于以下两个方面:

  • 数据分组:通过指定要分组的列或表达式,可以将查询结果按照指定的分组标准进行分组。这对于数据分析和生成报告非常有用,可以根据不同的分组条件来汇总数据
  • 聚合计算:在GROUP BY子句中,通常会结合使用聚合函数(如SUM、COUNT、AVG等)对每个分组的数据进行计算。这使得我们可以在每个分组上执行统计、汇总等操作

使用示例

下面是我们的一个Orders订单表,包含OrderIDCustomerID ProductQuantityPrice等订单信息字段,表信息如下所示:

OrderIDCustomerIDProductQuantityPrice
1101Product A510.0
2101Product B38.0
3102Product A210.0
4103Product C415.0
5103Product A610.0
  1. 分组查询

假设我们希望按照"Product"列对订单进行分组,并计算每个产品的总销售数量和总销售金额。我们可以使用以下查询:

SELECT Product, SUM(Quantity) AS TotalQuantity, SUM(Quantity * Price) AS TotalAmount
FROM Orders
GROUP BY Product;

SQL AS 关键字用来给字段起一个临时的别名,该别名只显示在结果集中,并不会更改原始表的字段名。执行结果:

+---------+--------------------+
| Product | TotalQuantity      |
+---------+--------------------+
|Product A|  13                |
|Product B|  3                 |
|Product C|  4                 |
+---------+--------------------+

+---------+--------------------+
| Product | TotalAmount      |
+---------+--------------------+
|Product A|  130               |
|Product B|  24                |
|Product C|  60                |
+---------+--------------------+

  1. 过滤分组

我们可以在GROUP BY子句中使用条件来过滤特定的分组。例如,我们只想计算销售数量大于等于5的产品的总金额,可以使用以下查询:

SELECT Product, SUM(Quantity * Price) AS TotalAmount
FROM Orders
GROUP BY Product
HAVING SUM(Quantity) >= 5;

结果如下:

+---------+--------------------+
| Product | TotalAmount      |
+---------+--------------------+
|Product A|  130               |

总结

GROUP BY子句是SQL中一个重要的语法元素,用于分组和聚合查询结果。通过指定分组列和应用聚合函数,我们可以根据不同的分组标准来生成有用的汇总数据。在实际的数据库查询中,灵活运用GROUP BY子句可以帮助我们更好地理解和分析数据,从而支持决策和报告的生成。记得根据示例和语法规则进行实践,并在实际的数据分析任务中掌握GROUP BY子句的应用。

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

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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

VSCode安装 PlatformIO 插件指南

公众号阅读: 前言 在前几次发的文章中多次提到PlatformIO这个VSCode插件,很多同学私信我说非常难安装,希望我继续分享如何在国内快速安装PlatformIO。其实PlatformIO官网提供了详细的安装文档和PIO的使用手册。大家可以参考官网文档。本文将…

第十课:计算机心理学、教育科技及奇点,天网,计算机的未来

第十课:计算机心理学、教育科技及奇点,天网,计算机的未来 第三十八章:计算机心理学0、计算机中用到的心理学原理1、易用度2、颜色强度排序和颜色排序3、分组更好记4、直观功能5、认出VS回想6、让机器有一定的情商以及Facebook的研…

案例094:基于微信小程序的图书馆自习室座位预约管理系统

文末获取源码 开发语言:Java 框架:SSM JDK版本:JDK1.8 数据库:mysql 5.7 开发软件:eclipse/myeclipse/idea Maven包:Maven3.5.4 小程序框架:uniapp 小程序开发软件:HBuilder X 小程序…

Unraid APP下载慢解决方法

1.首先你的APP商城能够打开 这里我已下载Jellyfin为例 使用APP查找镜像,是为了获取下面的配置模板 2.修改地址 默认的地址是 lscr.io/linuxserver/jellyfin服务器在国外,被墙了.下载具慢 我们需要把这个下载源修改成国内的 有很多国内的源,但是我觉得阿里的比较快 3.获…

低代码UI构件程序设计基础实训一

步骤一 低代码在线调试工具 网址 低代码在线调试工具 步骤二 D盘建一个文件夹,文件夹下建两个文件夹ico和js 网上找一些图片,后缀.png,编号从0开始,图片另存到ico文件夹下 下载(右键另存为)以下四个页面…

discard long time none received connection

使用DruidDataSource 做数据源时,如果创建的连接在长时间得不到调用后会报如题所示的错误 discard long time none received connection. ,jdbcUrl : jdbc:mysql://localhost:3306/test?autoReconnecttrue&useUnicodetrue&characterEncodingutf8&serverTimezoneC…

C语言编译器(C语言编程软件)完全攻略(第三部分:Windows下的编译器有哪些?如何选择?)

介绍常用C语言编译器的安装、配置和使用。 三、Windows下的编译器有哪些?如何选择? 安装编译器或者 IDE(集成开发环境),也叫搭建开发环境。Windows 下的C语言 IDE 众多,多如牛毛,初学者往往不…

信号强度功能 界面、逻辑和图标(免费)

信号强度 需求 vue项目,需要实时监控系统信号,要求: 1.共五格信号; 2.信号0-100为满值,信号100-500为四格,信号500-1000为三格,信号1000-5000为两格,信号5000-20000为一格&#x…

Python学习笔记(五)函数、异常处理

目录 函数 函数的参数与传递方式 异常处理 函数 函数是将代码封装起来,实现代码复用的目的 函数的命名规则——同变量命名规则: 不能中文、数字不能开头、不能使用空格、不能使用关键字 #最简单的定义函数 user_list[] def fun(): #定义一个函数&…

微软 Power Platform 使用Power Automate发送邮件以Dataverse作为数据源的附件File Column

微软Power Platform使用Power Automate发送邮件添加Power Apps以Dataverse作为数据源的附件File Column方式 目录 微软Power Platform使用Power Automate发送邮件添加Power Apps以Dataverse作为数据源的附件File Column方式1、需求背景介绍2、附件列File Column介绍3、如何在Po…

华焰天下隆重推出华火智能电燃灶产品,引领绿色科技新潮流!

近日,以“慧聚英雄南昌,论道策划科技——畅展华焰未来,迈向财富新时代”为主题的华火新能源产品发布会于江西南昌盛大举办。 各级领导、全国各地的企业家、家电行业优秀从业者、新能源应用领域专家、策划行业名人大咖及广大媒体朋友莅临活动…

小心JDK20 ZipOutputStream

Oracle 團隊竟然這麽粗心,編譯JDK 20 時ZipOutputStream沒有編譯成功就發佈了。 所以這個20版本不可以使用ZipOutputStream。 GZIPInputStream 只能做最後的壓縮,不能添加多個附件ZipEntry。 下一個版本21不存在這個問題。 try(var zipOut new ZipOu…

LabVIEW开发智能水泵监测系统

LabVIEW开发智能水泵监测系统 水泵作为水利、石化、农业等领域的重要设备,其能效与健康状态直接关系到提灌泵站的运行效率。尽管水泵机组在全球能源消耗中占有显著比例,但实际运行效率常因设备老化和维护不当而远低于预期。这一状况需要更高效的监测手段…

Spring Boot 整合 Knife4j(快速上手)

关于 Knife4j 官方文档:https://doc.xiaominfo.com/ Knife4j是一个基于Swagger的API文档生成工具,它提供了一种方便的方式来为Spring Boot项目生成在线API文档。Knife4j的特点包括: 自动化生成:通过Swagger注解,Kn…

黑马程序员SpringBoot2-运维实用篇

视频连接:运维实用篇-51-工程打包与运行_哔哩哔哩_bilibili 打包与运行 程序打包与运行(Windows) 可执行jar包目录结构 左上角的结构是没有插件打包后的结构,左下是安装插件后的结构。 jar包描述文件(MANIFEST.MF&a…

Python Gradio构建简单的交互界面

Gradio 是一个用于构建机器学习和数据科学的交互式应用程序的 Python 库,但是我们可以用它来构建一些简单的交互界面,其代码之简单令人震惊 文本输入输出 import gradio as grdef szu(text):return textinterface gr.Interface(fnszu, inputs"text…

开发知识点-Java网络编程-Netty

Netty P1 Netty-导学分布式网络返回 异步结果dubbo rabbitmqtest 测试案例多线程 日志 第1章_01_nio三大组件-channel-buffer网络编程 框架jdk 1.4 之后才有 nio这个 APIChannel 数据传输通道 (双向)Buffer 内存缓冲区 (暂存Channel 的 数据&…

Babylonjs 6.0文档 Deep Dive - 摄像机介绍(一)

摄像机 在Babylon.js的众多的可用摄像机中,最常用的两种可能是用于“第一人称”运动的通用相机、轨道相机ArcRotateCamera,以及用于现代虚拟现实体验的WebXRCamera。 为了允许用户输入,摄像机必须被附加在canvas中 camera.attachControl(c…
最新文章