MySQL零散拾遗(四)--- 使用聚合函数时需要注意的点点滴滴

聚合函数

聚合函数作用于一组数据,并对一组数据返回一个值。
常见的聚合函数:SUM()MAX()MIN()AVG()COUNT()

对COUNT()聚合函数的更深一层理解

COUNT函数的作用:计算指定字段在查询结果中出现的个数(不包含NULL值)

如果计算表中有多少条记录,如何实现?

方式1:COUNT(*)
方式2:COUNT(1)
方式3:COUNT(具体字段):不一定对!
为什么说使用方式3,得到的结果不一定正确呢?这是因为 COUNT 计算字段出现的个数时,是不计算NULL值的。或者说,COUNT(*)会统计值为 NULL 的行,而 COUNT(字段)不会统计此字段为 NULL 值的行

举个栗子,需求:查询公司中平均奖金率

SELECT  SUM(commission_pct)/COUNT(commission_pct)
FROM employees;

上面的 mysql 代码 是错误的,因为 并不是所有的员工都有奖金率,可能存在没有奖金的员工,他/她的commission_pct字段的记录为 NULL
正确的mysql语句如下:

SELECT SUM(commission_pct) / COUNT(IFNULL(commission_pct,0)), AVG(IFNULL(commission_pct,0))
FROM employees;

如何需要统计表中的记录数,使用COUNT(*)、COUNT(1)、COUNT(具体字段) 哪个效率更高呢?

如果使用的是 MyISAM 存储引擎,则三者效率相同,都是O(1)
如果使用的是 InnoDB 存储引擎,则三者效率:COUNT(*) = COUNT(1) > COUNT(字段)

GROUP BY 的一些鲜为人知的事儿

SELECT 中出现的非组函数的字段必须声明在 GROUP BY 中。反而,在 GROUP BY 中声明的字段可以不出现在SEELCT中。

SELECT job_id,department_id,AVG(salary)
FROM employees
GROUP BY job_id,department_id;

GROUP BY声明在FROM后面,WHERE后面,ORDER BY前面,LIMIT前面。

当使用ROLLUP时,不能同时使用ORDER BY子句进行结果排序,即ROLLUP和ORDER BY是互相排斥的。

HAVING 的小秘密

  • 如果过滤条件中使用了聚合函数,则必须使用 HAVING 来替换 WHERE,否则报错。
  • HAVING 必须声明在 GROUP BY 的后面。
  • 在开发中,我们使用HAVING的前提是 SQL 中使用了 GROUP BY
SELECT department_id,MAX(salary)
FROM employees
GROUP BY department_id
HAVING MAX(salary) > 10000;

当过滤条件中没有聚合函数时,则此过滤条件声明在WHERE中或HAVING中都可以,但是建议大家声明在WHERE中。

WHEREHAVING 的对比

  1. 从适用范围上来讲,HAVING的适用范围更广。
  2. 如果过滤条件中没有聚合函数:这种情况下,WHERE的执行效率要高于HAVING

SELECT查询的结构

方式1

SELECT ...,....,...FROM ...,...,....WHERE 多表的连接条件
AND 不包含组函数的过滤条件
GROUP BY ...,...HAVING 包含组函数的过滤条件
ORDER BY ... ASC/DESCLIMIT ...,...

方式2

SELECT ...,....,...
FROM ... JOIN ... 
ON 多表的连接条件
JOIN ...
ON ...
WHERE 不包含组函数的过滤条件
AND/OR 不包含组函数的过滤条件
GROUP BY ...,...
HAVING 包含组函数的过滤条件
ORDER BY ... ASC/DESC
LIMIT ...,...

其中:

1from:从哪些表中筛选
(2on:关联多表查询时,去除笛卡尔积
(3where:从表中筛选的条件
(4group by:分组依据
(5having:在统计结果中再次筛选
(6order by:排序
(7limit:分页

SELECT语句执行顺序

FROM -> WHERE -> GROUP BY -> HAVING -> SELECT 的字段 -> DISTINCT -> ORDER BY -> LIMIT
在这里插入图片描述

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

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

相关文章

ElMessage自动引入,样式缺失和ts esline 报错问题解决

一. 环境 "unplugin-auto-import": "^0.17.6", "vue": "^3.3.8", "vite": "^5.0.0", "typescript": "^5.2.2",二. ElMessage样式缺失问题. 以下有两种解决方法 方法一: 配置了自动引用后…

TypeScript-Omit/Pick

文章目录 Omit 的词源词源分析词源历史 在 TypeScript 中的用法示例 Pick语法示例更复杂的示例使用 Pick 和其他类型组合实际应用场景 Omit vs Pick Omit 的词源 Omit 是一个英语词汇,它的意思是“省略”或“遗漏”。现在让我们来看看这个词的词源。 词源分析 O-…

从应答到解决:深度剖析电话客服热线系统的核心功能与价值

一、引言 在当今这个信息时代,客户服务的质量直接关系到企业的生存和发展。电话客服热线系统作为企业与客户之间沟通的桥梁,发挥着至关重要的作用。 1.电话客服热线系统的重要性 电话客服热线系统是企业与客户之间最直接、最有效的沟通渠道之一。它不…

Oracle集群RAC磁盘管理命令asmcmd的使用

文章目录 ASM磁盘共享简介ASM磁盘共享的优势ASM磁盘组成ASM磁盘共享的应用场景Asmcmd简介Asmcmd的功能Asmcmd的命令Asmcmd的使用注意事项Asmcmd运行模式交互模式运行非交互模式运行ASMCMD命令分类实例管理命令:文件管理命令:磁盘组管理命令:模板管理命令:文件访问管理命令:…

Python文献调研(一)环境搭建

一、安装Python版本 1.点击进入Python官网 Download Python | Python.org 2.根据自己的需求选择python的版本,点击【Download】 3.自定义安装路径,记得勾选Add Python xxx to PATH 这步是自动配置环境变量的,如果忘记勾选,建议…

VirtualBox 安装Centos 7 避坑指南 SSH连不上 镜像失效 静态网络配置等

背景 几乎每次安装Centos 7 时,都会遇到各种各样的问题,毕竟每次安装动辄就是半年几年,几乎都是在换工作时,有了新机器才会倒腾一次,时间久远,就会忘记一些细节,这次整理一下,避免以…

如何定位线上OOM

造成OOM的原因 1一次性申请太多对象。如:从数据库获取大量数据。 解决方法:更改申请对象的数量。如:做个分页。 2内存资源使用完未释放。如:太多线程建立数据库连接而未释放。 解决方法:使用线程池。 3本身资源不够…

Android笔试面试题AI答之线程Handler、Thread(2)

答案仅供参考,来自 讯飞星火大模型 目录 1.Android多线程间通信和多进程之间通信有什么不同,分别怎么实现?2.请解释下在单线程模型中Message、Handler、Message Queue、Looper之间的关系?3.Android 线程间通信有哪几种方式?4.子线程发消息…

虚拟机学习

虚拟机的优点: 为什么要使用虚拟机?VMware安装使用_研究虚拟机的意义-CSDN博客 虚拟机使用教程: 手把手从安装本地虚拟机,基于docker,部署springbootvue项目(若依框架前后端分离版本演示)&am…

Linux---01---安装VMware

一. 什么时Linux Linux 是一个开源的类 Unix 操作系统,Linux 是许多计算机硬件的底层操作系统,特别是服务器、嵌入式系统和个人电脑。它支持多种架构,包括 x86、x64、ARM 和 MIPS 等。Linux 因其稳定性、安全性、开源性以及广泛的社区支持而广受欢迎。 …

VPN与加密隧道:确保网络数据传输的安全

在信息时代,数据安全和隐私保护成为了网络用户和企业关注的焦点。随着远程工作和分布式办公环境的普及,保障数据在互联网上安全传输显得尤为重要。虚拟私人网络(Virtual Private Network, VPN)和加密隧道技术在这一背景下扮演了至…

如何压缩视频大小不改变画质?这5个视频压缩免费软件超好用!

如何压缩视频大小不改变画质?随着生活的水平逐步提高,视频流媒体服务越来越受欢迎。提供简短而引人注目的视频来展示您的产品或服务已成为一种出色的营销手段。然而,当您要准备导出最终视频时,可能会面临一个常见问题:…

小规模的LLMS

对于小模型来说,训练目标已经改变。关键问题是,AI系统如何从更少的数据中学到更多 我们需要模型先变得更大,再变得更小,因为我们需要「巨兽」将数据重构、塑造为理想的合成形式,逐渐得到「完美的训练集」,…

算法之递归算法

递归是非常常见的一种算法, 也比较难以理解,简而言之,递归就是写了一个方法,方法中还调用了该方法,相当于自己调用自己,如果书写不当,就会有堆栈溢出的风险,无法跳出。 所以我们编写…

【Rust光年纪】选择适合你的项目:Rust语言云平台SDK大比拼

构建稳健的云服务:深度评析Rust语言云平台SDK 前言 随着云计算和跨平台开发的不断发展,越来越多的开发者开始关注使用Rust语言进行云服务开发。本文将介绍几个用于Rust语言的主流云平台SDK,探讨它们的核心功能、安装与配置方法以及API概览&…

虚拟机centos9搭建wordpress

目录 1. 更换yum源更新系统软件包: 1.1备份yum源 1.1.1创建备份目录: 1.1.2移动现有仓库配置文件到备份目录: 1.1.3验证备份: 1.2更换yum源 1.2.1添加yum源 1.2.2删除和建立yum缓存 1.3更新系统软件包 1.4 yum与dnf介绍…

RV1126 Linux 系统,接外设,时好时坏(二)排查问题的常用命令

在 RV1126 Linux 系统中,排查外设连接问题时,可以使用多种命令来诊断和调试。以下是一些常用的命令和工具: 1. 查看系统日志 dmesg: 显示内核环形缓冲区的消息,通常包含设备初始化、驱动加载和错误等信息。 dmesg | grep <设备名或相关关键字>journalctl: 查看系统…

做短视频素材哪里找?去哪里下载?自媒体下载素材网站分享

自媒体视频创作&#xff1a;高质量素材网站大公开&#xff01; 大家好&#xff0c;我是一名热情的短视频创作者。今天&#xff0c;我要与大家分享一些寻找优质视频素材的秘诀。无论是新手还是老手&#xff0c;这些建议都能帮助你的视频在众多平台中脱颖而出&#xff0c;吸引更…

Python:jsonl文件转json文件,并做字段处理

在使用LLaMA-Factory对shenzhi-wang/Llama3-8B-Chinese-Chat&#xff08;https://huggingface.co/shenzhi-wang/Llama3-8B-Chinese-Chat/tree/main&#xff09;进行微调时&#xff0c;希望使用COIG-CQIA的小红书数据集&#xff08;https://huggingface.co/datasets/m-a-p/COIG-…

JVM 11 的优化指南:如何进行JVM调优,JVM调优参数有哪些

这篇文章将详细介绍如何进行JVM 11调优&#xff0c;包括JVM 11调优参数及其应用。此外&#xff0c;我将提供12个实用的代码示例&#xff0c;每个示例都会结合JVM启动参数和Java代码。 本文已收录于&#xff0c;我的技术网站 java-broke.site&#xff0c;有大厂完整面经&#x…