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)

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

相关推荐
2301_76628344几秒前
MySQL数据误删除后如何快速恢复_基于binlog日志的闪回操作
jvm·数据库·python
duke8692672141 分钟前
Bootstrap中常用的文本颜色、背景颜色及边框色类
jvm·数据库·python
m0_740352426 分钟前
React 中的渲染(Rendering)机制详解.txt
jvm·数据库·python
Navicat中国7 分钟前
如何通过数据分析功能解锁数据深度洞察?
数据库·数据挖掘·数据分析·navicat
weixin_444012937 分钟前
WooCommerce 用户登录状态控制元素显隐的 CSS 实现方案
jvm·数据库·python
kexnjdcncnxjs8 分钟前
CSS Grid布局如何实现固定页脚效果_利用网格高度视口百分比单位
jvm·数据库·python
爱喝水的鱼丶9 分钟前
SAP-ABAP:SAP 系统变量 SY-INDEX 学习笔记:从 1 开始的循环计数器
运维·开发语言·数据库·sap·abap
Jetev9 分钟前
MongoDB GridFS的默认MD5计算在集群中消耗CPU怎么办
jvm·数据库·python
dblens 数据库管理和开发工具10 分钟前
数据库工具装进了一个 Agent:DBLens for MariaDB 上线
数据库·mariadb
Jetev10 分钟前
CSS如何实现复杂圣杯布局_结合flex布局与flex-basis轻松实现
jvm·数据库·python