最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

oracle--rollup和cube分组累计求和

来源:懂视网 责编:小采 时间:2020-11-09 09:42:57
文档

oracle--rollup和cube分组累计求和

oracle--rollup和cube分组累计求和:group by 语句支持基本的having条件,还支持rollup和cube提供信息汇总功能,类似小计。 rollup:纵向小计,从右向左逐个对每一列进行小结并在结果中生成独立的一行。只返回第一个分组条件指定的列的统计行。 cube:横行小计 selectd.deptno,
推荐度:
导读oracle--rollup和cube分组累计求和:group by 语句支持基本的having条件,还支持rollup和cube提供信息汇总功能,类似小计。 rollup:纵向小计,从右向左逐个对每一列进行小结并在结果中生成独立的一行。只返回第一个分组条件指定的列的统计行。 cube:横行小计 selectd.deptno,

group by 语句支持基本的having条件,还支持rollup和cube提供信息汇总功能,类似小计。 rollup:纵向小计,从右向左逐个对每一列进行小结并在结果中生成独立的一行。只返回第一个分组条件指定的列的统计行。 cube:横行小计 selectd.deptno,t.job,sum(t.sal)

group by 语句支持基本的having条件,还支持rollup和cube提供信息汇总功能,类似小计。

rollup:纵向小计,从右向左逐个对每一列进行小结并在结果中生成独立的一行。只返回第一个分组条件指定的列的统计行。

cube:横行小计

  1. select d.deptno,t.job,sum(t.sal) from emp t,dept d
  2. where t.deptno=d.deptno
  3. 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

此时要求不显示最后总计行:

  1. select d.deptno,t.job,sum(t.sal) from emp t,dept d
  2. where t.deptno=d.deptno
  3. group by rollup(d.deptno,t.job)having grouping_id(d.deptno,t.job)<=1

执行结果:

实际情况中要展示结果集中汇总列加上小计和合计,此时这样处理:

执行结果:

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

oracle--rollup和cube分组累计求和

oracle--rollup和cube分组累计求和:group by 语句支持基本的having条件,还支持rollup和cube提供信息汇总功能,类似小计。 rollup:纵向小计,从右向左逐个对每一列进行小结并在结果中生成独立的一行。只返回第一个分组条件指定的列的统计行。 cube:横行小计 selectd.deptno,
推荐度:
标签: 分组 求和 g
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top