当前位置: 首页 > news >正文

oracle-函数-grouping sets(x1,x2,x3...)的妙用

GROUPING SETS 允许你为多个列组合生成分组汇总。它类似于多个 GROUP BY 子句的 UNION ALL 操作,但更加简洁和高效

首先:创建表及接入测试数据


create table students
(id number(15,0),
area varchar2(10),
stu_type varchar2(2),
score number(20,2));
insert into students values(1, '111', 'g', 80 );
insert into students values(1, '111', 'j', 80 );
insert into students values(1, '222', 'g', 89 );
insert into students values(1, '222', 'g', 68 );
insert into students values(2, '111', 'g', 80 );
insert into students values(2, '111', 'j', 70 );
insert into students values(2, '222', 'g', 60 );
insert into students values(2, '222', 'j', 65 );
insert into students values(3, '111', 'g', 75 );
insert into students values(3, '111', 'j', 58 );
insert into students values(3, '222', 'g', 58 );
insert into students values(3, '222', 'j', 90 );
insert into students values(4, '111', 'g', 89 );
insert into students values(4, '111', 'j', 90 );
insert into students values(4, '222', 'g', 90 );
insert into students values(4, '222', 'j', 89 );
commit;

sql示例:

select id, area, stu_type, sum(score) score
from students
group by grouping sets((id, area, stu_type), (id, area), id)
order by id, area, stu_type;
  1. (id, area, stu_type):按照 idarea 和 stu_type 三个字段进行分组,求出每个分组的 score 总和。
  2. (id, area):按照 id 和 area 两个字段进行分组,求出每个分组的 score 总和。
  3. id:仅按照 id 字段进行分组,求出每个分组的 score 总和。

GROUPING SETS 等效于 UNION ALL 的写法 

select * from (select id, area, stu_type, sum(score) from students group by id, area, stu_typeunion allselect id, area, null, sum(score) from students group by id, areaunion allselect id, null, null, sum(score) from students group by id
) order by id, area, stu_type;

 总结:

  • GROUPING SETS 是一种非常强大的 SQL 分组和聚合工具,它让我们能够在同一个查询中对多种不同的列组合进行聚合,避免了重复编写多个 GROUP BY 子句的麻烦,并且比使用 UNION ALL 更加高效。理解 GROUPING SETS 可以帮助我们在分析数据时获得更多层次的汇总信息。
  • GROUPING SETS:提供了最大的灵活性,允许你指定任意的列组合进行分组汇总。你可以精确地控制哪些列组合需要进行聚合,而不像 ROLLUPCUBE 那样会自动生成所有的汇总维度。

http://www.lryc.cn/news/478657.html

相关文章:

  • 人工智能在医疗病例诊断中的应用与展望
  • OceanBase 安装使用详细说明
  • CI_CD
  • Linux -- 初识线程
  • Uniapp底部导航栏设置(附带PS填充图标教程)
  • 单智能体carla强化学习实战工程介绍
  • 潮玩宇宙方块兽系统开发:可定制UI与多种游戏内嵌助力个性化体验
  • 什么是低代码?3000字低代码超全解读!
  • 雷池社区版7.1新版本自定义NGINX配置分析
  • [SAP ABAP] 面向对象程序设计-类和对象
  • 『大模型笔记』IBM技术团队:什么是智能体型RAG!
  • WPF 中 NavigationWindow 与 Page 的继承关系解析
  • WebRTC基础理论和通话原理
  • NPU 可不可以代替 GPU
  • Vue3版本的uniapp项目运行至鸿蒙系统
  • 部署stable-diffusion3.5 大模型,文生图
  • 数据采集之selenium模拟登录
  • 机器学习中的两种主要思路:数据驱动与模型驱动
  • 【计算机网络】TCP协议面试常考(一)
  • C#/.NET/.NET Core学习路线集合,学习不迷路!
  • 使用哈希表做计数排序js
  • 京津冀自动驾驶技术行业盛会|2025北京自动驾驶技术展会
  • Chrome与火狐哪个浏览器的隐私追踪功能更好
  • 探索 Python 图像处理的瑞士军刀:Pillow 库
  • JavaScript中的if、else if、else 和 switch
  • Python 使用 langchain 过程中的错误总结
  • MySQL基础篇总结
  • 全面解析:网络协议及其应用
  • 一文了解Java序列化
  • 【前端基础】CSS基础