-
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
相关推荐
yurenpai(27届找实习中)34 分钟前
redis_点评(21.好友关注——关注、取关功能实现;共同关注功能实现)Rick199335 分钟前
索引的排序和分组爱莉希雅&&&36 分钟前
zabbix快速搭建和使用JohnYan1 小时前
工作笔记 - PG分组极值清溪5491 小时前
DataEase H2 JDBC-RCE(CVE-2025-32966)复现ServBay1 小时前
不要再盲选了,PostgreSQL、MySQL与SQLite真实性能对比Trouvaille ~1 小时前
【Redis篇】Set 与 Zset:集合运算与排行榜的终极武器無限進步D1 小时前
MySQL 创建和管理表六月雨滴1 小时前
归档模式配置与切换卡次卡次12 小时前
vibecoding起步注意点:插件、Skills、MCP、Hooks