【Java 进阶篇】深入理解 SQL 聚合函数

news2025/5/21 15:00:59

在这里插入图片描述

在 SQL 数据库中,聚合函数是一组强大的工具,用于处理和分析数据。它们可以帮助您对数据进行统计、计算总和、平均值、最大值、最小值等操作。无论您是数据库开发者、数据分析师还是希望更好地了解 SQL 数据库的用户,了解聚合函数都是非常重要的。

本文将深入探讨 SQL 中的聚合函数,包括其基本语法、常见的聚合函数类型、使用示例以及一些高级用法。

1. 什么是 SQL 聚合函数?

在开始深入了解 SQL 聚合函数之前,让我们先了解一下它们的基本概念。SQL 聚合函数是一组用于在数据库表的列上执行计算的函数。它们通常用于执行统计操作,例如计算总行数、总和、平均值、最大值或最小值。聚合函数能够将一列的多个值合并为一个单一的值,并提供对数据的有用摘要。

SQL 中的常见聚合函数包括 COUNT()SUM()AVG()MAX()MIN(),它们可用于不同类型的数据操作。聚合函数通常与 GROUP BY 子句结合使用,以根据一个或多个列对数据进行分组,并在每个分组上执行聚合计算。

2. 常见的 SQL 聚合函数

让我们首先介绍 SQL 中的一些常见聚合函数以及它们的用途。

COUNT()

COUNT() 函数用于计算某列中的行数。它通常用于确定数据集中的记录数量。例如,以下是一个使用 COUNT() 函数的查询示例:

SELECT COUNT(*) FROM orders;

这将返回 orders 表中的总行数。

SUM()

SUM() 函数用于计算某列中所有数值的总和。它常用于计算数值型列的总和。例如,以下是一个使用 SUM() 函数的查询示例:

SELECT SUM(price) FROM products;

这将返回 products 表中 price 列的总和。

AVG()

AVG() 函数用于计算某列中所有数值的平均值。它通常用于计算数值型列的平均值。例如,以下是一个使用 AVG() 函数的查询示例:

SELECT AVG(age) FROM employees;

这将返回 employees 表中 age 列的平均年龄。

MAX()

MAX() 函数用于查找某列中的最大值。它通常用于查找数值型列的最大值,也可用于日期或文本列。例如,以下是一个使用 MAX() 函数的查询示例:

SELECT MAX(salary) FROM employees;

这将返回 employees 表中 salary 列的最高工资。

MIN()

MIN() 函数用于查找某列中的最小值。它通常用于查找数值型列的最小值,也可用于日期或文本列。例如,以下是一个使用 MIN() 函数的查询示例:

SELECT MIN(stock_price) FROM stocks;

这将返回 stocks 表中 stock_price 列的最低股价。

3. 使用 GROUP BY 子句进行分组

在许多情况下,我们希望对数据进行分组并在每个分组上执行聚合函数,以便更细致地分析数据。这时就需要使用 GROUP BY 子句。

GROUP BY 子句

GROUP BY 子句用于将结果集按照一个或多个列的值进行分组。它允许我们在每个分组上应用聚合函数,从而生成每个分组的摘要信息。下面是一个示例,演示如何使用 GROUP BY 子句:

SELECT department, AVG(salary)
FROM employees
GROUP BY department;

在上述查询中,我们将 employees 表按照 department 列的值分组,并计算每个部门的平均工资。这将返回每个部门的平均工资摘要信息。

4. HAVING 子句的用法

HAVING 子句允许我们在 GROUP BY 子句之后对分组的结果进行过滤。它通常用于筛选分组后的数据,类似于 WHERE 子句对原始数据进行筛选的方式。以下是一个示例:

SELECT department, AVG(salary)
FROM employees
GROUP BY department
HAVING AVG(salary) > 50000;

在上述查询中,我们首先按部门分组,然后筛选出平均工资大于 50000 的部门。这将返回符合条件的部门及其平均工资。

5. 嵌套聚合函数

SQL 允许我们在聚合函数内部使用其他聚合函数,以进行更复杂的计算。例如,我们可以计算每个部门的最高工资与最低工资之差。以下是一个示例:

SELECT department, MAX(salary) - MIN(salary)
FROM employees
GROUP BY department;

这将返回每个部门的最高工资与最低工资之差。

6. SQL 聚合函数的高级用法

除了上述基本用法外,SQL 聚合函数还有一些高级用法,可以帮助我们更好地分析和摘要数据。

使用 DISTINCT 关键字

有时我们需要对唯一的值进行聚合计算,而不是考虑所有的行。这时可以使用 DISTINCT 关键字来确保只考虑唯一的值。以下是一个示例:

SELECT COUNT(DISTINCT department) FROM employees;

在上述查询中,我们计算了不同部门的数量,而不考虑重复的部门。

使用聚合函数计算百分比

聚合函数还可用于计算百分比或比例。例如,我们可以计算每个部门的工资在总工资中的百分比:

SELECT department, SUM(salary) / (SELECT SUM(salary) FROM employees) * 100 AS percentage
FROM employees
GROUP BY department;

在这个查询中,我们计算了每个部门的工资总和与总工资之比,并将其乘以 100 以获得百分比。

使用聚合函数进行数据透视

聚合函数还可以用于数据透视,将数据表重新排列为透视表。透视表将不同的列值作为行,聚合函数的结果作为列。这在分析数据时非常有用。

7. 总结和注意事项

在本文中,我们深入探讨了 SQL 中的聚合函数,包括其基本用法、常见的聚合函数类型和高级用法。聚合函数是 SQL 数据库中强大的工具,可用于统计、计算和摘要数据。以下是一些总结和注意事项:

  • 常见的 SQL 聚合函数包括 COUNT()SUM()AVG()MAX()MIN()
  • GROUP BY 子句用于将结果集分组,并在每个分组上执行聚合函数。
  • HAVING 子句用于在分组后对结果进行过滤。
  • SQL 允许嵌套聚合函数,以进行更复杂的计算。
  • 使用 DISTINCT 关键字可以确保只考虑唯一的值进行聚合计算。
  • 聚合函数可用于计算百分比、比例和进行数据透视,有助于更深入地分析数据。

在使用聚合函数时,需要注意以下几点:

  • 理解数据的结构和需要的计算,选择合适的聚合函数。
  • 使用 GROUP BY 子句将数据分组,以便按照特定的标准进行摘要。
  • 使用 HAVING 子句对分组后的数据进行过滤,只选择符合条件的分组。
  • 嵌套聚合函数时,确保计算的顺序和逻辑正确。
  • 考虑使用 DISTINCT 关键字来处理唯一值的计算。
  • 当计算百分比和比例时,确保分母不为零,以避免错误。
  • 在进行数据透视时,了解透视表的结构,以便更好地组织和理解数据。

总之,SQL 聚合函数是处理和分析数据的重要工具,掌握它们的用法可以帮助您更好地理解和利用数据库中的信息。无论您是数据库开发人员、数据分析师还是普通用户,了解如何使用聚合函数都将提高您在 SQL 数据库中工作的效率和能力。希望本文对您深入学习 SQL 聚合函数提供了有用的指导和信息。

作者信息

作者 : 繁依Fanyi
CSDN: https://techfanyi.blog.csdn.net
掘金:https://juejin.cn/user/4154386571867191

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

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

相关文章

三个要点,掌握Spring Boot单元测试

单元测试是软件开发中不可或缺的重要环节,它用于验证软件中最小可测试单元的准确性。结合运用Spring Boot、JUnit、Mockito和分层架构,开发人员可以更便捷地编写可靠、可测试且高质量的单元测试代码,确保软件的正确性和质量。 一、介绍 本文…

(SAR)Sentinel-1影像自动下载

基于ASF网站提供的python代码,实现Sentinel-1影像的自动下载; 1、登录ASF网站 登录Sentinel-1影像ASF网站:https://search.asf.alaska.edu/; 点击网站最右侧Sign in图标,进行用户注册; 注册完用户之后&…

基于Vue+ELement实现增删改查案例与表单验证(附源码)

🎉🎉欢迎来到我的CSDN主页!🎉🎉 🏅我是Java方文山,一个在CSDN分享笔记的博主。📚📚 🌟推荐给大家我的专栏《ELement》。🎯🎯 &#x1…

I2C外设

I2C的总结 I2C优点: 接口线少只有两根线,控制方式简单,通信速率较高; I2C 是飞利浦公司开发的两线式串行总线; I2C缺点: 硬件比较复杂,稳定性不太好,程序移植有点麻烦&#xff…

自定义v-resize指令并发布到NPM

自定义Vite库并发布到NPM 封装useResize 用于监听绑定元素的宽高变化,当元素宽高发生变化时触发回调并获取最新的宽高 新建项目 结合上面学到的 Hook 和 自定义指令封装一个监听元素宽高变化的指令,并发布到 npm 项目结构 useResize ├…

jQuery核心卷

目录 一.jQuery引用 二.jQuery语法 三.元素的属性 1.attr()方法 2.使用removeAttr()方法删除HTML元素的属性 3.使用text()方法设置HTML元素的文本内容 四.CSS元素控制 1.使用css()方法获取和设置css属性 2.与CSS类别有关的方法 3.获取和设置HTML元素的尺寸 4.获取和…

html 边缘融合加载

html 代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>边缘融合加载</title><style>* {margin: 0;padding: 0;box-sizing: border-box;}body {height: 100vh;padding-bottom: 80px;b…

No141.精选前端面试题,享受每天的挑战和学习

🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6 🍨 阿珊和她的猫_CSDN个人主页 🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 🍚 蓝桥云课签约作者、已在蓝桥云课上架的前后端实战课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入…

【STM32】IAP升级00 预备知识

IAP&#xff08;In Application Programming&#xff09;简介 Flash够大的情况下&#xff0c;上电后的程序通过修改 MSP 的方式&#xff0c;可以在一块Flash上存在多个功能差异的程序。 IAP是为了在执行正常功能前&#xff0c;为了升级功能&#xff0c;提前运行的一段程序。这…

26608-2011 工业用回收一氯甲烷 学习笔记

声明 本文是学习GB-T 26608-2011 工业用回收一氯甲烷. 而整理的学习笔记,分享出来希望更多人受益,如果存在侵权请及时联系我们 1 范围 本标准规定了工业用回收一氯甲烷的要求、试验方法、检验规则及标志、包装、运输、贮存及安全。 本标准适用于副产回收生产的工业用一氯甲…

一些杂题(9.23)

八月赛 A. Extra Large Knapsack 我的思路 是否可行只要看所有异或在一起是否为0就可以了 可行的方案只要有一个在第一个包里&#xff0c;剩下的都在第二个包里就可以了 注意&#xff1a;n1的时候不可行&#xff0c;要特判 代码 #include<bits/stdc.h> using name…

手写Hystrix基本原理

本文已收录于专栏 《中间件合集》 目录 概念说明什么是HystrixHystrix解决的问题 提供服务工作流程代码实现HystrixSDKMyHystrixCommand注解MyHystrixProperty注解MyAspect注解解释器 发送请求端引入Hystrix的依赖调用代码 接收请求端执行效果发送请求端 总结提升 概念说明 什…

树莓集团又一力作,打造天府蜂巢成都直播产业园样板工程

树莓集团再次推出惊艳之作&#xff0c;以打造成都天府蜂巢直播产业园为目标。该基地将充分展现成都直播产业园的巨大潜力与无限魅力&#xff0c;成为一个真正的产业园样板工程。 强强联手 打造未来 成都天府蜂巢直播产业园位于成都科学城兴隆湖高新技术服务产业园内&#xff0…

毕业设计选题之Java+springboot线上蔬菜销售与配送系统(源码+调试+开题+lw)

&#x1f495;&#x1f495;作者&#xff1a;计算机源码社 &#x1f495;&#x1f495;个人简介&#xff1a;本人七年开发经验&#xff0c;擅长Java、Python、PHP、.NET、微信小程序、爬虫、大数据等&#xff0c;大家有这一块的问题可以一起交流&#xff01; &#x1f495;&…

基于Java的药品管理系统设计与实现(源码+lw+部署文档+讲解等)

文章目录 前言具体实现截图论文参考详细视频演示为什么选择我自己的网站自己的小程序&#xff08;小蔡coding&#xff09;有保障的售后福利 代码参考源码获取 前言 &#x1f497;博主介绍&#xff1a;✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域优质创作…

国庆节难忘回家路:趣事、风景、反思

文章目录 前言趣事游记旅途风光在人气爆棚的小七孔古桥大七孔在喯珠泻玉的拉雅瀑布奇异罕见的水上森林在云雾缭绕的鸳鸯湖在天然地宫——天钟洞飞瀑流泉 反思人们在死亡之前自己会有预感吗&#xff1f;求索生死大问 中秋国庆的规划后记 前言 中秋国庆&#xff0c;双节汇在一起…

8、绩效看板与日清计划

6、片花关联长视频 7、脏话检测 内容仓的办公区挂着几台电视&#xff0c;显示每个人目前完成的工作量&#xff0c;这就是绩效看板&#xff08;如下图&#xff09;&#xff0c;每位来参观的领导&#xff0c;都觉得这个绩效看板的想法很有意思。绩效看板是制造业常用的管理方法&…

【数据结构初阶】六、线性表中的队列(链式结构实现队列)

相关代码gitee自取&#xff1a; C语言学习日记: 加油努力 (gitee.com) 接上期&#xff1a; 【数据结构初阶】五、线性表中的栈&#xff08;顺序表实现栈&#xff09;_高高的胖子的博客-CSDN博客 1 . 队列&#xff08;Queue&#xff09; 队列的概念和结构&#xff1a; 队列…

基于Java的食堂管理系统设计与实现(源码+lw+部署文档+讲解等)

文章目录 前言系统功能具体实现截图论文参考详细视频演示为什么选择我自己的网站自己的小程序&#xff08;小蔡coding&#xff09;有保障的售后福利 代码参考源码获取 前言 &#x1f497;博主介绍&#xff1a;✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域…

【设计模式】备忘录模式

文章目录 1.备忘录模式定义2.备忘录模式的角色3.备忘录模式实现3.1.场景说明3.2.结构类图3.3.代码实现 4.备忘录模式优缺点5.备忘录模式适用场景6.备忘录模式总结 主页传送门&#xff1a;&#x1f481; 传送 1.备忘录模式定义 备忘录&#xff08;Memento Pattern&#xff09;模…