oracle中having的用法,深入浅析SQL中的group by 和 having 用法
一、sql中的group by 用法解析:
Group By语句从英文的字面意义上理解就是“根据(by)一定的规则进行分组(Group)”。
作用:通过一定的规则将一个数据集划分成若干个小的区域,然后针对若干个小区域进行数据处理。
注意:group by 是先排序后分组!
举例说明:如果要用到group by 一般用到的就是“每”这个字, 例如现在有一个这样的需求:查询每个部门有多少人。就要用到分组的技术
select DepartmentID as '部门名称',COUNT(*) as '个数'
from BasicDepartment
group by DepartmentID
这个就是使用了group by +字段进行了分组,其中我们就可以理解为我们按照部门的名称ID
DepartmentID将数据集进行了分组;然后再进行各个组的统计数据分别有多少;
二、group by 和having 解释
前提:必须了解sql语言中一种特殊的函数——聚合函数。
例如:SUM, COUNT, MAX, AVG等。这些函数和其它函数的根本区别就是它们一般作用在多条记录上。
WHERE关键字在使用集合函数时不能使用,所以在集合函数中加上了HAVING来起到测试查询结果是否符合条件的作用。
having称为分组过滤条件,也就是分组需要的条件,所以必须与group by联用。
需要注意说明:当同时含有where子句、group by 子句 、having子句及聚集函数时,执行顺序如下:
1、执行where子句查找符合条件的数据;
2、使用group by 子句对数据进行分组;
3、对group by 子句形成的组运行聚集函数计算每一组的值;
4、最后用having 子句去掉不符合条件的组。
having 子句中的每一个元素也必须出现在select列表中。有些数据库例外,如oracle.
having子句和where子句都可以用来设定限制条件以使查询结果满足一定的条件限制。
having子句限制的是组,而不是行。聚合函数计算的结果可以当条件来使用,where子句中不能使用聚集函数,而having子句中可以。
总结
以上所述是小编给大家介绍的SQL中的group by 和 having 用法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
oracle中having的用法,深入浅析SQL中的group by 和 having 用法相关推荐
- oracle的nvl函数用法,nvl函数(sql中nvl函数的使用)
谁解释一下nvl()函数有什么用啊,是干什么的,简明扼要,谢谢 NVL(E1, E2)的功能为:如果E1为NULL,则函数返回E2,否则返回E1本身. 用法:查询不相等数据 功能:如果string1为 ...
- oracle sql 匹配 一位,关于在SQL中查找匹配间隔:在SQL中查找匹配间隔-Oracle
我有一张桌子: 表: START END 1 Jan 09 31 Jan 2009 1 Feb 09 28 Feb 2009 1 Mar 09 31 Mar 2009 ...
- fastreport.net 交叉表居中显示_浅析Sql中内连接、外连接、全连接、交叉连接的区别...
外连接(out join) 外连接分为外左连接(left outer join)和外右连接(right outer join) 注释:left outer join 与 left join 等价, 一 ...
- pl/sql中的赋值运算符_如何在SQL中使用AND / OR运算符?
pl/sql中的赋值运算符 Basically, AND / OR operator is used to retrieving the record from the database. If we ...
- python3的格式化用法_浅析python3字符串格式化format()函数的简单用法
format()函数 """ 测试 format()函数 """ def testformat(): # format()函数中有几个元素, ...
- js 中meta 移除head_浅析JS中数据结构
目录 列表(链表) 数组 栈 队列 哈希表 堆 图 二叉查找树 分享一句话:算法即原力,即正义 列表(链表) 链表是一种数据元素按照链式存储结构进行存储的数据结构,这种存储结构具有在物理上存在非连续的 ...
- Oracle的Cast的用法,cast函数(sql中cast函数用法)
这是一个格式转换函数.里面有两个参数:cast[要转换的数据或公式 as 转换到的数据类型] 同类函数还有convert[数据类型,要转换的数据或公式] CAST()和CONVERT()函数的区别是什 ...
- java中exists是什么_JAVA:sql中exists的用法
exists:强调的是是否返回结果集,不要求知道返回什么,比如:selectnamefromstudentwheresex='m'andmarkexists(select1fromgradewhere ...
- sql left join用法_图解 SQL 中 JOIN 的各种用法
点击上方"Java知音",选择"置顶公众号" 技术文章第一时间送达! 作者:CodingStar cnblogs.com/BoyceYang/p/3145279 ...
最新文章
- 关注WebWork(四)
- 分子生物学-氨基酸电中性与肽键
- [BZOJ] 1637: [Usaco2007 Mar]Balanced Lineup
- eclipse工程导入Android Studio
- IIS 启动不了(服务没有及时响应启动或控制请求)解决
- mysql router docker_MySQL Router 完全讲解
- Linux网络设置(第二版) --互联网寻址过程
- 行云管家堡垒机的使用方法之二——新增登录凭证
- Golang快速入门
- ensp配置access口_eNSP初学者配置以太网2种链路端口:access、trunk
- Exercise39: python字典(访问,操作,list(), dirt.items(), dirt.get() )
- spring核心技术之Resource资源理解
- 2-2 李宏毅2021春季机器学习教程-类神经网络训练不起来怎么办(一)局部最小值与鞍点(Local Minima and Saddle Point)
- springboot报错:Could not get a resource from the pool redis.clients.jedis.exceptions.JedisConnection
- 计算机科学丛书之第9章和第10章代码
- Qt编写的项目作品11-带频谱的音乐播放器
- 《树莓派项目实战》第十二节 使用PCA9685驱动板控制多个舵机
- 苹果三代耳机_预告2020.6.13其他团无线蓝牙耳机
- python qrcode 库的使用
- 咏春拳段位首次开考先考动作再考功力2008-11-13