【重学 MySQL】三十九、Having 的使用

news2024/9/27 6:57:00

【重学 MySQL】三十九、Having 的使用

  • 基本语法
  • 示例
    • 示例 1:使用 `HAVING` 过滤分组
    • 示例 2:`HAVING` 与 `WHERE` 的结合使用
  • 注意点
  • `WHERE` 与 `HAVING` 的对比
    • 基本定义与用途
    • 主要区别
    • 示例对比
    • 总结

在这里插入图片描述

在 MySQL 中,HAVING 子句主要用于对 GROUP BY 语句产生的分组结果进行条件过滤。虽然 WHERE 子句也用于设置条件以过滤记录,但 WHERE 无法直接对聚合函数(如 COUNT(), MAX(), MIN(), SUM(), AVG() 等)的结果进行过滤。这正是 HAVING 子句的用武之地。

基本语法

SELECT column_name(s), AGGREGATE_FUNCTION(column_name)
FROM table_name
WHERE condition
GROUP BY column_name(s)
HAVING condition
ORDER BY column_name(s);

示例

假设我们有一个名为 orders 的表,包含字段 order_id, customer_id, order_date, 和 amount

示例 1:使用 HAVING 过滤分组

如果我们想要找出订单总额超过 1000 的客户,我们可以使用 GROUP BYHAVING 来实现:

SELECT customer_id, SUM(amount) AS total_amount
FROM orders
GROUP BY customer_id
HAVING SUM(amount) > 1000;

这个查询会返回所有订单总额超过 1000 的 customer_id 以及他们对应的订单总额。

示例 2:HAVINGWHERE 的结合使用

虽然 HAVING 主要用于对聚合函数的结果进行过滤,但它也可以与 WHERE 子句一起使用,其中 WHERE 子句用于在分组前过滤记录,而 HAVING 子句用于在分组后过滤结果。

SELECT customer_id, SUM(amount) AS total_amount
FROM orders
WHERE order_date > '2023-01-01'  -- 过滤 2023 年 1 月 1 日之后的订单
GROUP BY customer_id
HAVING SUM(amount) > 1000;       -- 过滤订单总额超过 1000 的客户

这个查询会首先筛选出 2023 年 1 月 1 日之后的订单,然后按 customer_id 进行分组,并计算每个客户的订单总额,最后只返回订单总额超过 1000 的客户及其订单总额。

注意点

  • HAVING 子句在 GROUP BY 子句之后执行,因此对分组后的结果进行过滤。
  • HAVING 可以使用聚合函数,而 WHERE 子句则不能。
  • 在实际应用中,如果条件可以在数据分组前通过 WHERE 子句进行过滤,则应优先使用 WHERE,因为 WHERE 过滤的数据更少,有助于提高查询效率。
  • HAVING 子句也支持使用别名(如上例中的 total_amount),但只能在 HAVING 子句中引用,不能在 WHERE 子句中引用。
  • 当过滤条件中有聚合函数时,则此过滤条件必须声明在 HAVING 中,当过滤条件中没有聚合函数时,则此过滤条件声明在 WHEREHAVING 中都可以,但是,建议大家声明在 WHERE

WHEREHAVING 的对比

在SQL中,WHEREHAVING是两个用于过滤数据的关键字,它们虽然功能相似,但在使用场景和效果上存在显著差异。

基本定义与用途

  • WHERE

    • WHERE子句是SQL查询中用于筛选结果集的可选部分。
    • 它使用布尔表达式来限制返回的行数,筛选数据并检索特定信息。
    • WHERE子句在数据分组(如果有的话)之前进行过滤,基于表中的列数据来限制返回的数据行。
  • HAVING

    • HAVING子句是一个与GROUP BY子句配合使用的条件语句,用于在数据分组后对分组结果进行过滤。
    • 它基于分组后的聚合结果进行筛选,可以使用聚合函数(如SUM、AVG、COUNT等)和逻辑操作符。

主要区别

  1. 使用时机

    • WHERE子句在数据分组之前进行过滤,而HAVING子句在数据分组之后进行过滤。
    • 如果没有使用GROUP BY子句,则HAVING的行为与WHERE类似,但HAVING支持聚合函数的使用,而WHERE不支持。
  2. 支持的函数

    • WHERE子句不能使用聚合函数作为过滤条件。
    • HAVING子句可以使用聚合函数作为过滤条件,因为它是在分组后对聚合结果进行筛选。
  3. 字段别名

    • WHERE子句中,通常不能直接使用字段别名(在某些数据库系统中可能支持,但这不是标准行为)。
    • HAVING子句中,可以使用字段别名(尤其是当别名是基于聚合函数的结果时)。
  4. 执行顺序

    • 在SQL查询的执行顺序中,WHERE子句早于GROUP BY子句执行,而HAVING子句则在GROUP BY之后执行。

示例对比

假设有一个名为orders的表,包含order_idcustomer_idsales_amount等字段,我们想要找出销售额大于1000美元的客户。

  • 使用WHERE(假设不分组,仅筛选):

    SELECT customer_id, sales_amount
    FROM orders
    WHERE sales_amount > 1000;
    

    这个查询将返回所有销售额大于1000美元的单条订单记录。

  • 使用HAVING(假设按客户分组):

    SELECT customer_id, SUM(sales_amount) AS total_sales
    FROM orders
    GROUP BY customer_id
    HAVING total_sales > 1000;
    

    这个查询将首先按customer_id分组订单,然后计算每个客户的总销售额,并返回总销售额大于1000美元的客户组。

总结

WHEREHAVING在SQL查询中各自扮演着重要的角色,它们的主要区别在于使用时机、支持的函数、字段别名的使用以及执行顺序。了解这些区别对于编写有效的SQL查询至关重要。

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

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

相关文章

进阶SpringBoot之 Dubbo-admin 安装测试

Dubbo 是一个 jar 包,本身并不是一个服务软件 它能让 Java 程序连接到 Zookeeper,并利用 Zookeeper 消费、提供服务 Dubbo-admin 是一个可视化的监控程序,可以让用户更好的管理监控众多的 Dubbo 服务 GitHub dubbo-admin 在项目目录下打包…

MyBatis<foreach>标签的用法与实践

foreach标签简介 实践 demo1 简单的一个批量更新&#xff0c;这里传入了一个List类型的集合作为参数&#xff0c;拼接到 in 的后面 &#xff0c;来实现一个简单的批量更新 <update id"updateVislxble" parameterType"java.util.List">update model…

代码随想录算法训练营第56天 | 1、冗余连接,2、冗余连接II

目录 1、冗余连接 2、冗余连接II 1、冗余连接 题目描述 有一个图&#xff0c;它是一棵树&#xff0c;他是拥有 n 个节点&#xff08;节点编号1到n&#xff09;和 n - 1 条边的连通无环无向图&#xff08;其实就是一个线形图&#xff09;&#xff0c;如图&#xff1a; 现在在…

UNI-SOP应用场景(1)- 纯前端预开发

在平时新项目开发中&#xff0c;前端小伙伴是否有这样的经历&#xff0c;hi&#xff0c;后端小伙伴们&#xff0c;系统啥时候能登录&#xff0c;啥时候能联调了&#xff0c;这是时候往往得到的回答就是&#xff0c;再等等&#xff0c;我们正在搭建系统呢&#xff0c;似曾相识的…

Marp精华总结(一)基础篇

概述 Marp是一个基于MarkDown快速编写幻灯片的工具&#xff0c;其可以基于VScode环境&#xff0c;实现MarkDown幻灯的编写和预览。Marp并不难&#xff0c;但是目前的教程还比较零散&#xff0c;而且很多细节和高级内容并没有完全展示&#xff0c;我自己是很早就体验到了Marp的…

C语言进阶之泛型列表(Generic List)

1.前言 数据结构是需要泛型的,而在C语言中实现泛型就只能去用指针魔法了,来跟我一起实现吧!所有代码经测试未发现明显bug,可放心食用. 2.代码截图展示 1.list.h 2.main.c 3.list.c 3.结语 这次分享的列表采用动态数组的方式实现,下次我会去用链表实现,两种实现方式各有优劣,希…

通信工程学习:什么是VIM虚拟化基础设施管理器

VIM:虚拟化基础设施管理器 VIM(Virtualized Infrastructure Manager)虚拟化基础设施管理器,是一种负责管理和控制虚拟化环境中所有虚拟资源的工具和系统。以下是关于VIM虚拟化基础设施管理器的详细解释: 一、定义与功能 VIM是网络功能虚拟化(NFV)架构中…

DVWA-File Inclusion(文件包含)渗透测试

概念&#xff1a; 漏洞产生原因&#xff1a; 主要是由于开发人员没有对用户输入的文件路径进行严格的过滤和验证。例如&#xff0c;如果一个 Web 应用程序接受用户输入的文件路径&#xff0c;然后使用这个路径进行文件包含&#xff0c;而没有对用户输入进行任何检查&#xff0c…

dll 研究 1

起因&#xff0c; 目的: 就是想看看 dll 里面有什么。 过程: 找到&#xff0c;打开 dumpbin 在开始菜单中搜索 “Developer Command Prompt for VS”打开&#xff0c; 然后输入 dumpbin 查看 a.dll 中 dumpbin /headers a.dll 查看头部信息dumpbin /EXPORTS a.dlldumpbin /a…

基于SSM+小程序的在线课堂微信管理系统(在线课堂1)(源码+sql脚本+视频导入教程+文档)

&#x1f449;文末查看项目功能视频演示获取源码sql脚本视频导入教程视频 1 、功能描述 &emsp1、管理员实现了首页、个人中心、用户管理、课程分类管理、课程信息管理、课程订阅管理、课程视频管理、公告栏管理、留言板管理、系统管理。 2、用户实现了首页、课程信息、公…

Web3Auth 如何工作?

Web3Auth 用作钱包基础设施&#xff0c;为去中心化应用程序 (dApp) 和区块链钱包提供增强的灵活性和安全性。在本文档中&#xff0c;我们将探索 Web3Auth 的功能&#xff0c;展示它如何为每个用户和应用程序生成唯一的加密密钥提供程序。 高级架构 Web3Auth SDK 完全存在于用…

消息号 FS215 对科目 2221010200 7333允许销项税, J1 不允许

业务场景&#xff1a; 在做发票校验时&#xff0c;报错“消息号 FS215 对科目 2221010200 7333允许销项税, J1 不允许”而且计算税额失效&#xff0c;红灯报错。 初步怀疑是税码配置问题 FTXP J1是进项税&#xff0c;但是这里维护了销项税和均一税&#xff0c;在这里删除是需…

【Python开发环境搭建】在pycharm中使用虚拟环境进行开发

每个虚拟环境都是独立的&#xff0c;打包生成的exe文件更加小巧&#xff0c;不会因为兼容性问题出现干扰 1、打开项目后&#xff0c;在右下角点击Python解释器&#xff0c;选择添加新的解释器&#xff0c;添加本地解释器 2、选择新建&#xff0c;选择合适的路径&#xff0c;取…

商业终端数据打包-android-鸿蒙——国产系统-———未来之窗行业应用跨平台架构

一、未来之窗星辰传送阵炼化炉横空出世 以下是为您编写的引言&#xff1a; 在当今的网络世界中&#xff0c;网页隔段时间就提示登录的现象令人困扰&#xff0c;严重影响了终端交互的流畅性。传统的设备 ID 识别方式存在无法动态变更数据的局限&#xff0c;轮询模式更是会使服务…

C# 利用simd比较两个文件是否相等(高性能)

主要用到两个指令集&#xff0c;CompareEqual指令与MoveMask指令&#xff0c;因为电脑cpu原因&#xff0c;我们采用Avx2。 Avx2.CompareEqual&#xff0c;比较两个Vector256<byte>向量&#xff0c;如果元素相同返回255&#xff0c;否则返回0。 Avx2.MoveMask如果Vector…

滚珠丝杠在人形机器人及线控制动和转向中大放异彩

直线驱动器用于对旋转角度不大、高负载的场景,在人形机器人中多用于四肢。直线驱动器多采取“电机+丝杠”,将旋转运动转为关节末端的直线运动,能够起到较好的支撑和承重效果,能够较好的适配应用场景的负载需求。 特斯拉人形机器人Optimus 双足、双臂采用连杆结构,连杆末端…

GS-SLAM论文阅读笔记--GEVO

前言 这篇文章看着就让人好奇。众所周知&#xff0c;高斯是一个很不错的建图方法&#xff0c;但是本文的题目居然是只用高斯进行单目VO&#xff0c;咱也不知道这是怎么个流程&#xff0c;看了一下作者来自于MIT&#xff0c;说不定是个不错的工作&#xff0c;那就具体看看吧&am…

IDEA服务启动时无法输出日志

起服务时&#xff0c;控制台啥日志也没有 解决方案&#xff1a;选择【启用调试输出】 SQL的日志无法打印 原来安装了一个Mybatis Log Free&#xff0c;用的好好的。 后来换了个项目&#xff0c;SQL执行日志就打印不出来了。 解决方案&#xff1a;换个插件&#xff0c;我换了…

Python语言把二进制转成十六进制

0 Preface/Foreword 0.1 10进制转其他进制 bin()oct()hex() 0.2 其他进制转10进制 int(, 2)int(, 8)int(, 16) 1 转换方法 1.1 方法1 先将二进制转成10进制&#xff0c;再将10进制转成16进制 decim int(00000101, 2) hexadecim hex(decim) print hexadecim 1.2 方法…

Snap AR眼镜Spectacles的技术揭秘:通往真正AR体验的道路

Snap公司自2010年成立以来&#xff0c;一直致力于探索增强现实&#xff08;AR&#xff09;技术的边界。经过多年的研发与迭代&#xff0c;Snap终于在最新一代Spectacles中实现了重大突破&#xff0c;为用户带来了前所未有的沉浸式AR体验。本文将深入探讨Spectacles的发展历程、…