group by 子句的细节

group by 子句的细节

GROUP BY子句主要用于对WHERE中得到的结果进行分组,也就是说它是在WHERE子句之后执行,对经过WHERE筛选后的结果按照某些列进行分组,之后进行相应的处理工作。

普通用法:
例如:显示部门平均工资的最大值
select max(avg(sal)) “部门平均工资的最大值”
from emp
group by deptno;

在select子句中出现的非多行函数的所有列,【必须】出现在group by子句中

例如:
select avg(sal) “部门平均工资的最大值”,deptno “部门编号”, mgr “领导”
from emp
group by deptno, mgr; deptno、mgr 就必须出现在group子句中

结果:
这里写图片描述

是不是笛卡尔集的知识在里面呢???

在group by子句中出现的所有列,【可出现可不现】在select子句中

还是上面的那个,avg(sal)就没有出现在group by子句中

聚集函数使用

当使用聚集函数的时候,除非对整个语句的查询结果集进行聚集运算,否则都要通过指定GROUP BY子句来确定是对某类结果集进行聚集运算
例如:
select owner,status,count(object_name) num from t; 错误
为什么错呢?
这是因为查询结果表中owner和status列下都有多条数据, 而count(object_name) 就是一条数据, 这样在形成结果表时, 就不对称了!!! 所以错误。

因此我们可以分完组后再进行聚集,即指定GROUP BY子句来确定是对某类结果集进行聚集运算
上面那条语句可以改成这样:
select owner,status,count(object_name) num from t group by owner,status; //也印证了前面两条细节
查询结果:
这里写图片描述

group by子句的限制

1)你不能在子句中使用LOB/VARRAYS/NESTED TABLE。
2)子句中的表达式不能是子查询语句
3)如果GROUP BY中引用了对象类型列,则这个查询就不能使用并行。

having

having也是对数据进行筛选的,不过他和where是有区别的。
where和having的区别:
where:
1)行过滤器
2)针对原始的记录
3)跟在from后面
4)where可省
5)先执行

having:
1)组过滤器
2)针对分组后的记录
3)跟在group by后面
4)having可省
5)后执行

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值