-
Oracle 版本: 19c ,Production version 19.3.0.0.0 Enterprise
-
使用场景:对结果集生成总计、小计效果
-
模拟数据:
数学 语文 学号 班级 90 80 0001 1班 80 95 0002 1班 77 99 0003 2班 95 85 0004 2班 -
例子 1(按照班级分组小计、班级总分) :
sqlSELECT NVL(班级,'总计') 班级, CASE WHEN 班级 IS NULL THEN '-' ELSE NVL(学号,'小计') END 学号, SUM(数学) 数学, SUM(语文) 语文 FROM score GROUP BY ROLLUP(班级,学号) ORDER BY 班级,学号班级 学号 数学 语文 1班 0001 90 80 1班 0002 80 95 1班 小计 170 175 2班 0003 77 99 2班 0004 95 85 2班 小计 172 184 总计 - 342 359 -
例子2 (只有总计)
sqlSELECT NVL(班级,'总计') 班级, CASE WHEN 班级 IS NULL THEN '-' ELSE NVL(学号,'小计') END 学号, SUM(数学) 数学, SUM(语文) 语文 FROM score GROUP BY ROLLUP((班级,学号)) -- 意思是 班级、学号组合分组 ORDER BY 班级,学号班级 学号 数学 语文 1班 0001 90 80 1班 0002 80 95 2班 0003 77 99 2班 0004 95 85 总计 - 342 359
Oracle中的Rollup 使用方法
米斯特程序猿2023-09-11 12:15
相关推荐
风123456789~32 分钟前
【OceanBase专栏】脚本调用OB过程实验n***s9095 小时前
【MySQL基础篇】概述及SQL指令:DDL及DML爬山算法5 小时前
Redis(158)Redis的主从同步问题如何解决?jnrjian7 小时前
FRA中 keep的backup set 不保险2501_941148157 小时前
多语言微服务架构与边缘计算技术实践:Python、Java、C++、Go深度解析w***z508 小时前
MYSQL 创建索引章鱼哥7309 小时前
[特殊字符] SpringBoot 自定义系统健康检测:数据库、Redis、表统计、更新时长、系统性能全链路监控5***E6859 小时前
MySQL:drop、delete与truncate区别记得记得就1519 小时前
【MySQL数据库管理】Austindatabases10 小时前
给PG鸡蛋里面挑骨头--杭州PostgreSQL生态大会