group by 语句支持基本的having条件,还支持rollup和cube提供信息汇总功能,类似小计。
rollup:纵向小计,从右向左逐个对每一列进行小结并在结果中生成独立的一行。只返回第一个分组条件指定的列的统计行。
cube:横行小计
select d.deptno,t.job,sum(t.sal) from emp t,dept d
where t.deptno=d.deptno
group by rollup(d.deptno,t.job)
执行结果:
***
使用grouping_id显示指定的分组级别的记录。返回grouping()位向量的十进制值,GROUPING位向量的计算方法是将按照顺序对每一列调用GROUPING函数的结果组合起来。
例:grouping_id(a,b,c),a为空就是0非空为1,b和c也一样,结果会得到一个三位数,用二进制转换成十进制就是了,a,b,c全是非空,即111就是7,三列就是7,如果是两列自然是11就是3
select ... from 表 group by rollup(.....) having grouping_id(....)<=1
rollup(x,y)2列 |
rollup(x,y,z)3列 |
总计是grouping_id=3 |
总计是grouping_id=7 |
小计grouping_id=1 |
小计grouping_id=3 |
记录是grouping_id=0 |
记录是grouping_id=0 |
此时要求不显示最后总计行:
select d.deptno,t.job,sum(t.sal) from emp t,dept d
where t.deptno=d.deptno
group by rollup(d.deptno,t.job)having grouping_id(d.deptno,t.job)<=1
执行结果:
实际情况中要展示结果集中汇总列加上小计和合计,此时这样处理:
select decode(grouping_id(deptno,job),1,'小计',3,'总计',job||deptno)
as group_col,sum(sal) from emp
group by rollup(deptno,job)
执行结果:
扩展:http://msdn.microsoft.com/zh-cn/library/bb510624.aspx
- 大小: 32 KB
- 大小: 29.8 KB
- 大小: 30.4 KB
分享到:
相关推荐
作者通过总结各自多年的软件开发和教学培训经验,与大家分享了掌握Oracle SQL所独有的丰富功能的技巧所在,内容涵盖SQL执行、联结、集合、分析函数、子句、事务处理等多个方面。读者可以学习到以下几个方面的技巧:...
8.3.3 ROLLUP运算符和CUBE运算符 8.3.4 GROUP BY子句中的NULL值处理 8.3.5 HAVING子句 8.3.6 HAVING子句与WHERE子句 8.3.7 SELECT语句各查询子句总结 第9章 多表查询 9.1 本章用到的实例表 ...
8.3.3 rollup运算符和cube运算符 151 8.3.4 group by子句中的null值处理 153 8.3.5 having子句 153 8.3.6 having子句与where子句 154 8.3.7 select语句各查询子句总结 156 第9章 多表查询 157 9.1 本章用到的...
精选570个典型范例,全面覆盖实用和热点技术,涉及面广,实用性强源于实际项目开发,帮助读者短时间掌握更多实用技术,提高编程水平范例经过精心编排,重点、难点突出,易学易懂书后附录提供快速索引,即查、即学、...
精选570个典型范例,全面覆盖实用和热点技术,涉及面广,实用性强源于实际项目开发,帮助读者短时间掌握更多实用技术,提高编程水平范例经过精心编排,重点、难点突出,易学易懂书后附录提供快速索引,即查、即学、...
精选570个典型范例,全面覆盖实用和热点技术,涉及面广,实用性强源于实际项目开发,帮助读者短时间掌握更多实用技术,提高编程水平范例经过精心编排,重点、难点突出,易学易懂书后附录提供快速索引,即查、即学、...
精选570个典型范例,全面覆盖实用和热点技术,涉及面广,实用性强源于实际项目开发,帮助读者短时间掌握更多实用技术,提高编程水平范例经过精心编排,重点、难点突出,易学易懂书后附录提供快速索引,即查、即学、...