当前位置: 首页 > news >正文

基础—SQL—DQL(数据查询语言)分组查询

一、引言

分组查询的关键字是:GROUP BY。

二、DQL—分组查询

1、语法

SELECT 字段列表 FROM 表名 [ WHERE 条件 ] GROUP BY 分组字段名 [ HAVING 分组后过滤条件 ];

注意

1、'[ ]' 里的内容可以有可以没有。

2、这条SQL语句有两块指定条件的地方,那它们之间有啥区别呢?

3、 WHERE 与 HAVING 区别:
(1)执行时机不同:WHERE 是
分组之进行过滤,不满足 WHERE 条件,不参与分组;而 HAVING分组之对结果进行过滤

(2)判断条件不同:WHERE 不能对聚合函数进行判断,而 HAVING 可以。

三、案例操作:

接下来回到 DataGrip 工具进行数据的分组查询学习和操作。

0、emp 表的初始数据

1、根据性别分组,统计男性员工和女性员工的数量
SELECT gender,COUNT(*) FROM emp GROUP BY gender;

2、 根据性别分组,统计男性员工和女性员工的平均年龄
SELECT gender,AVG(AGE) FROM emp GROUP BY gender;

3、查询年龄小于45的员工,并根据工作地址分组,获取员工数量大于等于3的工作地址 

首先可以查到:查询年龄小于45的员工,并根据工作地址分组

SELECT workaddress,COUNT(*) FROM emp WHERE age<45 GROUP BY workaddress;

然后经过 WHERE 分组后再进行分组条件的判断:(HAVING),再进行分组查询得出结果。也就是要在分组的基础上再过滤

SELECT workaddress,COUNT(*) AS address_count FROM emp WHERE age<45 GROUP BY workaddress HAVING address_count >=3;

四、总结 

1、分组查询要用到的关键字叫 GROUP BY

2、在分组之前过滤叫 WHERE ,分组之后过滤叫 HAVING

3、注意

(1)执行顺序:WHERE > 聚合函数 > HAVING 。

也就是说:WHERE 是在分组之前过滤的,分组的时候是在执行聚合函数,而 HAVING 是在我们分组聚合之后过滤的。

(2)分组之后,查询的字段一般为聚合函数和分组字段,查询其他字段无任何意义

举个例子说明:就第一个查询操作。

SELECT gender,COUNT(*) FROM emp GROUP BY gender;

根据编写的SQL语句的内容:聚合函数的字段是:COUNT(*),分组之后的字段是:gender 

而我们 SELECT 关键字后面跟着的就是这两个字段,也就是查询的字段是这两个。如果在SELECT 后面加一个 name 字段,那查出来的值无任何意义。

http://www.lryc.cn/news/359520.html

相关文章:

  • 从CSV到数据库(简易)
  • K210视觉识别模块学习笔记3:内存卡写入拍摄图片_LED三色灯的操作_按键操作_定时器的配置使用
  • 如何定义“智慧校园”这个概念
  • OpenSSL自签名证书
  • QtCreator调试运行工程报错,无法找到相关库的的解决方案
  • 【Python系列】Python 元组(Tuple)详解
  • 特征融合篇 | YOLOv8 引入动态上采样模块 | 超过了其他上采样器
  • ​​​​​​​Beyond Compare 3密钥被撤销的解决办法
  • 知识见闻 - 人和动物的主要区别
  • Javaweb基础之工程路径
  • 国际荐酒师(香港)协会受邀出席广州意大利国庆晚宴
  • 让驰骋BPM系统插上AI的翅膀
  • 排队论 | 基于排队机制实现智能仓储机器人巡逻及避碰
  • Node.js和npm常用命令
  • pytest +allure在测试中的应用
  • 004 CentOS 7.9 mongodb7.0.11安装及配置
  • Docker安装Redis(云服务器)
  • springboot中抽象类无法注入到ioc容器
  • Java关键字大冒险:深入浅出地理解Java的精髓
  • Android Kotlin 打开相册选择图片(多选)
  • java学习路径
  • [线程与网络] 网络编程与通信原理(四):深入理解传输层UDP与TCP协议
  • IEEE编程语言排行榜:深度解析编程语言的四大维度、五大趋势、六大热门与七大挑战
  • 【C++面试50题】
  • 外汇天眼:ESMA发布针对在投资服务中使用人工智能的公司的指导意见
  • 【前缀和 记忆化搜索】LeetCode1444. 切披萨的方案数
  • 异常处理1--5.31
  • AI免费插件 批量条码大师,支持100多种条码类型
  • 使用 Django 连接 MySQL 数据库
  • 【谷歌开发者月刊】五月内容汇总,Google I/O 点燃您的创新灵感