18_MySQL之HAVING字句的使用

本节涉及的sql语句:
-- HAVING
-- 错误示例
SELECT deptno
FROM t_emp
WHERE AVG(sal)>=2000
GROUP BY deptno; 因为where的执行优先于group by,所以在为分组之前,AVG函数不知道对那些结果进行求平均值,也就是说函数执行的优先级要在group by 之后,函数经常出现在select中,也就是说select优先级要在group by 之后,等select 结果出炉后,在进行排序,最后进行limit分页,所以各子句的优先顺序如下: FROM > WHERE > GROUP BY > SELECT > ORDER BY > LIMIT -- HAVING SELECT deptno,AVG(sal)
FROM t_emp
GROUP BY deptno
HAVING AVG(sal)>=2000; -- 查询每个部门中,1982年以后入职的员工超过2个人的部门编号 SELECT deptno
FROM t_emp
WHERE hiredate>"1982-01-01"
GROUP BY deptno HAVING count(*)>=2; -- HAVING中不能拿一个聚合函数和一个具体的字段比较,可以和数字比较 SELECT deptno
FROM t_emp
WHERE hiredate>"1982-01-01"
GROUP BY deptno HAVING count(*)>=2 AND sal>=AVG(sal);
引入HAVING字句原因:


以上语句执行报错
采用HAVING

练习



18_MySQL之HAVING字句的使用的更多相关文章
- MySql中having字句对组记录进行筛选使用说明
		having字句可以让我们筛选成组后的各种数据 having的用法 having字句可以让我们筛选成组后的各种数据,where字句在聚合前先筛选记录,也就是说作用在group by和having字句前 ... 
- Hibernate的查询语言之HQL(二)——Hibernate查询的from字句
		from 是最简单的HQL语句,也是最基本的HQL语句.from 关键字后紧跟持久化类的类名.例如: from Person 表明从Person持久化类中取出全部的实例. 大部分时候,推荐位该Pers ... 
- C#中let字句
		应用场景: 在查询表达式中,存储子表达式的结果有时很有用,这样可以在随后的子句中使用. 可以使用 let 关键字完成这一工作,该关键字可以创建一个新的范围变量,并且用您提供的表达式的结果初始化该变量. ... 
- hql语句中的select字句和from 字句
		package com.imooc.model; import java.util.List; import java.util.Map; import org.hibernate.Query; im ... 
- sql 选取分组中的第一条,显示聚合以外的列,having字句的使用
		分组中的第一条:select * from(select row_number() over(partition by 列1,列2,... order by 列1,列2,...) as rownum ... 
- 当子查询内存在ORDER BY 字句时查询会报错
		问题:当子查询内存在ORDER BY 字句时查询会报错 SQL: SELECT * FROM ( SELECT * FROM USER ORDER BY USER_CORD ) S. 解决办法:在子查 ... 
- TOP字句加SQL变量的相关问题
		SQL Server数据库中的变量可以加载TOP字句之后,下文将对TOP字句加SQL变量的相关问题进行讨论,供您参考,希望对您学习SQL数据库有所帮助. SQL Server2005开始,TOP子句后 ... 
- SQL Server ->> THROW字句对比RAISERROR子句
		SQL Server 2012开始引入了THROW字句用于替代从SQL Server开始沿用至今的RAISERROR.既然作用相同,都是在TRY... CATCH代码块后不抓错误然后抛出错误,它们之间 ... 
- WHERE字句
		structured query language(非过程性的结构查询语言) 主要内容: 数据库怎么限制里面的数据: 数据库怎么排列里面的数据. WHERE子句: --WHERE字句起到的是对数据库查 ... 
随机推荐
- 提高 Kafka 吞吐量
			提高 Kafka 吞吐量 1.了解分区的数据速率,以确保提供合适的数据保存空间 2.除非您有其他架构上的需要,否则在写 Topic 时请使用随机分区 3.如果 Consumers 运行的是比 Kafk ... 
- Cisco静态路由
			怎样让身在两个网段的终端会话交流呢?我们借用Cisco packet研究一下Cisco静态路由. 名词解释: 网关:(Gateway)网间连接器,或叫协议转换器:举例(参考https://baike. ... 
- 织梦dedecms自由列表的"不使用目录默认主页"错误修正
			站长用织梦做站时常常发现织梦自由列表有个致命的问题: 即修改"不使用目录默认主页"就永远不会自己勾选啦 打开这个文件 makehtml_freelist_action.php 搜索 ... 
- Python实现量子态采样
			什么是量子态矢量? 在前面一篇量子系统模拟的博客中,我们介绍了使用python去模拟一个量子系统演化的过程.当我们尝试理解量子态和量子门操作时,可以通过其矩阵形式的运算来描述量子态演化的过程: \[\ ... 
- The 2019 Asia Nanchang First Round Online Programming Contest C. Hello 2019(动态dp)
			题意:要找到一个字符串里面存在子序列9102 而不存在8102 输出最小修改次数 思路:对于单次询问 我们可以直接区间dpOn求出最小修改次数 但是对于多次询问 我在大部分题解看到的解释一般是用线段树 ... 
- [CF套题] CF-1201
			CF-1201 传送门 # = * A 500 B 1000 C 1500 D 2000 E1 2000 E2 1000 1 (2217) 1672 482 00:09 400 01:40 790 0 ... 
- POJ - 3693 Maximum repetition substring(重复次数最多的连续重复子串)
			传送门:POJ - 3693 题意:给你一个字符串,求重复次数最多的连续重复子串,如果有一样的,取字典序小的字符串. 题解: 比较容易理解的部分就是枚举长度为L,然后看长度为L的字符串最多连续出现 ... 
- hdu1217 Arbitrage
			Problem Description Arbitrage is the use of discrepancies in currency exchange rates to transform on ... 
- Base64 编码原理
			什么是 Base64 编码 Base64 编码是最常见的编码方式,基于 64 个可打印字符来表示任意二进制数据的方法,是从二进制转换到可见字符的过程. 使用场景 数据加密或签名通过 Base64 转换 ... 
- K8S(04)核心插件-coredns服务
			K8S核心插件-coredns服务 目录 K8S核心插件-coredns服务 1 coredns用途 1.1 为什么需要服务发现 2 coredns的部署 2.1 获取coredns的docker镜像 ... 
