11.Oracle中rollup函数详解

【基本介绍】

【格式】:group by rollup(字段1,字段2,字段3,...,字段n)

【说明】:rollup主要用于分组汇总,如果rollup中有n个字段,则会分别按【字段1】、【字段1,字段2】,【字段1,字段2,字段3】,...,【字段1,字段2,字段3,...字段n】进行分组统计,同时还会去掉所有分组字段进行一次统计,因此会有n+1次分组,也就是说,统计的分组维度是从左到右依次增加一列,从0列一直到n列。

【环境】:如下图是本次样例展示所使用的oracle版本。

select * from v$version

【准备样例数据】

样例数据如下图所示:

CLASS-班级,STUDENT-学生,SUBJECT-学科,GRADES-成绩。

【样例展示1】

执行如下sql语句:

select CLASS,sum(GRADES) from T_STUDENT_GRADES group by rollup(CLASS)

返回结果如下图所示:按班级对学生成绩进行分组计算总和,并将所有班级的总成绩进行汇总

【样例展示2】

执行如下sql语句:

select CLASS,STUDENT,sum(GRADES) from T_STUDENT_GRADES group by rollup(CLASS,STUDENT)

返回结果如下图所示:按班级、学生两个维度对成绩进行分组计算总和,并按班级将所有学生的成绩进行汇总,同时将所有班级的总成绩进行汇总

【样例展示3】

执行如下sql语句:

select CLASS,STUDENT,SUBJECT,sum(GRADES) from T_STUDENT_GRADES group by rollup(CLASS,STUDENT,SUBJECT)

返回结果如下图所示:按班级、学生、科目三个维度对成绩进行分组统计,并按班级、科目将学生的所有科目的成绩进行汇总,还按班级将所有学生的成绩进行汇总,同时将所有班级的总成绩进行汇总

相关推荐
就叫飞六吧1 小时前
mysql表字段反查表名脚本-筛选法-查表技巧
数据库·mysql
1.14(java)1 小时前
MySQL数据库操作全攻略
java·数据库·mysql
jmxwzy1 小时前
MySQL
数据库·mysql
自己的九又四分之三站台2 小时前
PostgreSQL:万物皆可PostgreSQL的力量
数据库·postgresql
一条大祥脚2 小时前
25.12.30
数据库·redis·缓存
雨中飘荡的记忆2 小时前
MyBatis SQL执行模块详解
数据库·sql·mybatis
飞Link3 小时前
【MySQL】Linux(CentOS7)下安装MySQL8教程
linux·数据库·mysql
数据库生产实战3 小时前
Oracle的_segment_count和3个event对高并发事务与索引性能的影响分析
数据库·oracle
程序员侠客行4 小时前
Mybatis二级缓存实现详解
java·数据库·后端·架构·mybatis
Tipriest_4 小时前
linux中的文本分接流tee命令介绍
linux·服务器·数据库