-
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
相关推荐
lu9up2 分钟前
业务表异常阻塞导致接口超时处理案例San30.21 分钟前
从 Mobile First 到 AI First:用 Python 和大模型让数据库“开口说话”古城小栈24 分钟前
PostgreSQL 【vs】 MySQL安全系统学习26 分钟前
网络安全漏洞之React 框架分析我科绝伦(Huanhuan Zhou)28 分钟前
Oracle RAC表空间从本地目录迁移至ASM磁盘组的两种实现方案生产队队长28 分钟前
Database:Navicat 连接 Oracle失败:logon deniedMisnice28 分钟前
MySQL 和 PostgreSQL 的区别YJlio30 分钟前
AI赋能编程语言:探索AI与开发的深度结合韩立学长31 分钟前
基于协同过滤算法的宠物收养系统f27ny63s(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。z***33537 分钟前
【MySQL】环境变量配置