【MySQL基础-9】深入理解MySQL中的聚合函数

在数据库操作中,聚合函数是一类非常重要的函数,它们用于对一组值执行计算并返回单个值。MySQL提供了多种聚合函数,如COUNTSUMAVGMINMAX等。这些函数在数据分析和报表生成中扮演着关键角色。本文将深入探讨这些聚合函数的使用方法、注意事项以及一些高级技巧。

1. 聚合函数概述

聚合函数主要用于对一组值进行计算,并返回一个单一的值。常见的聚合函数包括:

  • COUNT():计算行数。
  • SUM():计算数值列的总和。
  • AVG():计算数值列的平均值。
  • MIN():找出数值列的最小值。
  • MAX():找出数值列的最大值。

这些函数通常与GROUP BY子句一起使用,以便对分组后的数据进行聚合计算。

2. 常用聚合函数详解

2.1 COUNT()

COUNT()函数用于计算表中的行数。它可以用于计算所有行或满足特定条件的行。

-- 计算表中的总行数
SELECT COUNT(*) FROM employees;-- 计算特定条件下的行数
SELECT COUNT(*) FROM employees WHERE department = 'Sales';

2.2 SUM()

SUM()函数用于计算数值列的总和。

-- 计算所有员工的工资总和
SELECT SUM(salary) FROM employees;-- 计算特定部门的工资总和
SELECT SUM(salary) FROM employees WHERE department = 'Engineering';

2.3 AVG()

AVG()函数用于计算数值列的平均值。

-- 计算所有员工的平均工资
SELECT AVG(salary) FROM employees;-- 计算特定部门的平均工资
SELECT AVG(salary) FROM employees WHERE department = 'Marketing';

2.4 MIN()

MIN()函数用于找出数值列的最小值。

-- 找出所有员工中的最低工资
SELECT MIN(salary) FROM employees;-- 找出特定部门的最低工资
SELECT MIN(salary) FROM employees WHERE department = 'HR';

2.5 MAX()

MAX()函数用于找出数值列的最大值。

-- 找出所有员工中的最高工资
SELECT MAX(salary) FROM employees;-- 找出特定部门的最高工资
SELECT MAX(salary) FROM employees WHERE department = 'Finance';

3. 聚合函数与GROUP BY

GROUP BY子句用于将结果集按一个或多个列进行分组。聚合函数通常与GROUP BY一起使用,以便对每个分组进行聚合计算。

-- 按部门分组,计算每个部门的员工数
SELECT department, COUNT(*) FROM employees GROUP BY department;-- 按部门分组,计算每个部门的平均工资
SELECT department, AVG(salary) FROM employees GROUP BY department;

4. 聚合函数与HAVING

HAVING子句用于过滤分组后的结果集。与WHERE子句不同,HAVING可以用于过滤聚合函数的结果。

-- 找出平均工资大于5000的部门
SELECT department, AVG(salary) FROM employees GROUP BY department HAVING AVG(salary) > 5000;-- 找出员工数超过10人的部门
SELECT department, COUNT(*) FROM employees GROUP BY department HAVING COUNT(*) > 10;

5. 聚合函数的注意事项

  • NULL值处理:聚合函数通常忽略NULL值。例如,COUNT(column_name)不会计算NULL值。
  • 性能考虑:在大数据集上使用聚合函数可能会影响性能,尤其是在没有适当索引的情况下。
  • 数据类型:确保聚合函数应用于正确的数据类型。例如,SUM()AVG()应应用于数值列。

6. 高级技巧

6.1 使用DISTINCT

可以在聚合函数中使用DISTINCT关键字,以便只对唯一值进行计算。

-- 计算不同部门的数量
SELECT COUNT(DISTINCT department) FROM employees;-- 计算不同工资的总和
SELECT SUM(DISTINCT salary) FROM employees;

6.2 嵌套聚合函数

在某些情况下,可以嵌套使用聚合函数。

-- 计算每个部门的平均工资,然后找出这些平均工资中的最大值
SELECT MAX(avg_salary) FROM (SELECT AVG(salary) AS avg_salary FROM employees GROUP BY department) AS dept_avg;

6.3 使用窗口函数

MySQL 8.0及以上版本支持窗口函数,可以在不分组的情况下进行聚合计算。

-- 计算每个员工的工资以及所在部门的平均工资
SELECT employee_id, salary, AVG(salary) OVER (PARTITION BY department) AS avg_department_salary FROM employees;

7. 总结

聚合函数是MySQL中非常强大的工具,能够帮助我们轻松地对数据进行汇总和分析。通过结合GROUP BYHAVING子句,我们可以实现更复杂的数据分组和过滤操作。掌握这些函数的使用方法和注意事项,将极大地提升我们在数据库操作中的效率和灵活性。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Windows 图形显示驱动开发-WDDM 3.0功能- 硬件翻转队列(一)

WDDM 3.0 之前的翻转队列模型 许多新式显示控制器支持对按顺序显示的多个帧排队的能力。 从 WDDM 2.1 开始,OS 支持将在下一个 VSync 中显示的多个未完成的翻转覆盖请求。 显示微型端口驱动程序 (KMD) 通过 DXGK_DRIVERCAPS 中的 MaxQueuedMultiPlaneOverlayFlipVS…

OSPF-5 3类LSA SummaryLSA

上一期我们介绍了2类LSA Network LSA的内容信息以及怎样从2类LSA中的信息描绘出一张具体的拓扑信息以及网段信息 这一期我们将介绍3类LSA Summary LSA区域间的LSA看看3类LSA是怎样把域间的路由信息传递到别的区域的 一、概述 由于3类LSA是用来描述我们域间的路由信息所以它是…

AI驱动的视频字幕提取与翻译工具

青梧字幕是一款基于Whisper技术的AI字幕提取工具,专为视频制作者、翻译人员和自媒体创作者设计。它通过先进的语音识别算法,能够自动从视频文件中提取字幕内容,并支持多种语言和字幕格式,极大地简化了字幕制作流程。 目前暂支持 …

ONNX:统一深度学习工作流的关键枢纽

引言 在深度学习领域,模型创建与部署的割裂曾是核心挑战。不同框架训练的模型难以在多样环境部署,而 ONNX(Open Neural Network Exchange)作为开放式神经网络交换格式,搭建起从模型创建到部署的统一桥梁,完…

第十一次CCF-CSP认证(含C++源码)

第十一次CCF-CSP认证 打酱油满分题解 公共钥匙盒满分题解solution 1solution 2(优先队列优化) 通信网络(图的遍历问题)满分题解 打酱油 题目链接 满分题解 思路:做完这题我觉得这里有点像贪心算法但又是常识性问题&a…

深入解析Hosts文件:从原理到实战应用(文末附Qwins下载)

深入解析Hosts文件:从原理到实战应用 在网络世界中,一个看似普通的系统文件——Hosts文件,却隐藏着操控域名解析的“上帝权限”。无论是开发者的本地测试、网络安全防护,还是普通用户屏蔽广告,都离不开它的身影。本文将…

SpringBoot 和vue前后端配合开发网页拼图10关游戏源码技术分享

今天分享一个 前后端结合 的网页游戏 开发项目源码技术。 这也是我第一次写游戏类的程序,虽然不是特别复杂的游戏,但是是第一次写,肯定要记录一下了,哈哈。 游戏的内容 就是 我们显示中玩的那个 拼图碎片的 游戏,类似下…

TSB - AD 解读 — 迈向可靠、透明的 TSAD 任务

目录 一 文章动机 二 TSAD 领域内的两类缺陷 三 数据集的构建 四 实验结果及结论 项目宣传链接:TSB-AD 代码链接: TheDatumOrg/TSB-AD: TSB-AD: Towards A Reliable Time-Series Anomaly Detection Benchmark 原作者解读:NeurIPS 2…

Java 大视界 -- Java 大数据机器学习模型的对抗攻击与防御技术研究(137)

💖亲爱的朋友们,热烈欢迎来到 青云交的博客!能与诸位在此相逢,我倍感荣幸。在这飞速更迭的时代,我们都渴望一方心灵净土,而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识,也…

Python 鼠标轨迹算法 - 防止游戏检测

一.简介 鼠标轨迹算法是一种模拟人类鼠标操作的程序,它能够模拟出自然而真实的鼠标移动路径。 鼠标轨迹算法的底层实现采用C/C语言,原因在于C/C提供了高性能的执行能力和直接访问操作系统底层资源的能力。 鼠标轨迹算法具有以下优势: 模拟…

C++11 lambda表达式、包装器、Bind绑定

Hello!大家早上中午晚上好!!今天来复习C11三个新加的特性!! 一、lambda 表达式 1.1什么是lambda表达式? 语法:[捕捉列表](参数列表)->返回值{函数体}; …

计算机网络:(二)计算机网络在我国发展与网络类别与性能 (附带图谱更好对比理解)

计算机网络:(二)计算机网络在我国发展与网络类别和性能 前言一、计算机网络在我国的发展二、计算机网络的类别1. 计算机网络的定义2. 不同类别的计算机网络(1)按覆盖范围分类(2)按传输技术分类…

CoreData 调试警告:多个 NSEntityDescriptions 声明冲突的解决

概述 目前在苹果生态 App 的开发中,CoreData 数据库仍然是大部分中小应用的优先之选。不过,运行时 CoreData 常常产生各种“絮絮叨叨”的警告不禁让初学的秃头小码农们云里雾里。 这不,对于下面这一大段 CoreData 警告,大家是否一…

解决QT_Debug 调试信息不输出问题

方式1 &#xff1a;手动通过添加环境变量解决 ->使用命令&#xff1a; QT_LOGGING_TO_CONSOLE1 qtcreator启动 ->如若还未输出qDebug调试信息 则在程序中引<QLoggingCategory>包 #include <QLoggingCategory> ->在程序入口添加 QLoggingCategory::defa…

【CF】Day9——Codeforces Round 953 (Div. 2) BCD

B. New Bakery 题目&#xff1a; 思路&#xff1a; 被标签害了&#xff0c;用什么二分&#xff08; 很简单的思维题&#xff0c;首先如果a > b&#xff0c;那么全选a就行了&#xff0c;还搞啥活动 否则就选 b - a 天来搞活动&#xff0c;为什么&#xff1f; 首先如果我…

[MAVEN][经验总结]MAVEN_HOME和M2_HOME的配置建议

前言 MAVEN_HOME和M2_HOME都是maven的环境变量&#xff0c;要配置哪个&#xff0c;与maven版本有关&#xff0c;我在实操过程中遇到相关的问题&#xff0c;现记录如下。 MAVEN_HOME和M2_HOME的区别 MAVEN_HOME 和 M2_HOME 本质上是同一个作用的环境变量&#xff0c;它们的区…

力扣Hot100——169. 多数元素

解法1&#xff1a;使用HashMap 将nums数组映射到HashMap中&#xff0c;键为nums的值&#xff0c;值为nums中值的数量&#xff1b; 然后遍历哈希表&#xff0c;返回值最大的键 class Solution {private Map<Integer, Integer> countNums(int[] nums) {Map<Integer, Int…

EasyRTC嵌入式音视频通话SDK:微信生态支持、轻量化架构与跨平台兼容性(Linix/Windows/ARM/Android/iOS/LiteOS)

随着WebRTC技术的不断发展&#xff0c;实时音视频通信在各个领域的应用越来越广泛。EasyRTC嵌入式音视频通话SDK作为一款基于WebRTC技术的实时通信解决方案&#xff0c;凭借其强大的功能和灵活的集成能力&#xff0c;受到了越来越多开发者的关注。 一、系统架构设计 纯C语言开…

QuickAPI:一键将 Excel 数据转为数据库表

在开发和数据管理中&#xff0c;将 Excel 数据快速导入数据库是一项常见需求&#xff0c;但手动建表和导入的过程往往让人头疼。 QuickAPI 作为一款高效的统一数据服务平台&#xff0c;提供了一键将 Excel 数据转为数据库表的功能&#xff0c;极大简化了操作流程。本文将以技术…

【MySQL】多表查询(笛卡尔积现象,联合查询、内连接、左外连接、右外连接、子查询)-通过练习快速掌握法

在DQL的基础查询中&#xff0c;我们已经学过了多表查询的一种&#xff1a;联合查询&#xff08;union&#xff09;。本文我们将系统的讲解多表查询。 笛卡尔积现象 首先&#xff0c;我们想要查询emp表和stu表两个表&#xff0c;按照我们之前的知识栈&#xff0c;我们直接使用…