当前位置:网站首页>GBase 8a OLAP函数group by grouping sets的使用样例
GBase 8a OLAP函数group by grouping sets的使用样例
2022-06-27 19:33:00 【生命之源;】
GBase 8a的group grouping sets功能,对后面括号里的 n 个字段或表达式分别做 GROUP BY 操作,最后将结果合并在一起。等同于多个单独的group by后再做一个union all操作。
语法
GROUP BY GROUPING SETS( (…),(…),…)
说明
GROUP BY GROUPING SETS (A,B,C) (A、B、C 代表语法中的“(…)”)
首先对(A)进行 GROUP BY,然后对(B)进行 GROUP BY,然后对进行 GROUP BY,最后将所有结果合并在一起(相当于 UNION ALL 操作),如果 n 个字段或表达式中的一个或多个在某一分组中不出现在 GROUP BY 后面,用 NULL 代替不出现的字段或表达式。
样例
数据样例
简单的学生科目考试记录。
gbase> select * from score;
+--------+---------+-------+
| name | subject | score |
+--------+---------+-------+
| 王海 | 语文 | 86 |
| 王海 | 数学 | 83 |
| 王海 | 英语 | 93 |
| 陶俊 | 语文 | 88 |
| 陶俊 | 数学 | 84 |
| 陶俊 | 英语 | 94 |
| 刘可 | 语文 | 80 |
| 刘可 | 数学 | 86 |
| 刘可 | 英语 | 88 |
| 李春 | 语文 | 89 |
| 李春 | 数学 | 80 |
| 李春 | 英语 | 87 |
+--------+---------+-------+
12 rows in set (Elapsed: 00:00:00.01)
获得学生和学科各自的汇总结果
gbase> select name,subject,sum(score) from score group by grouping sets(name,subject);
+--------+---------+------------+
| name | subject | sum(score) |
+--------+---------+------------+
| NULL | 语文 | 343 |
| NULL | 数学 | 333 |
| NULL | 英语 | 362 |
| 王海 | NULL | 262 |
| 陶俊 | NULL | 266 |
| 刘可 | NULL | 254 |
| 李春 | NULL | 256 |
+--------+---------+------------+
7 rows in set (Elapsed: 00:00:00.02)
多个Sets之间也是union all关系。本例就简单的将上一个用例的2个条件,拆分一下。结果是一样的。
gbase> select name,subject,sum(score) from score group by grouping sets((name),(subject));
+--------+---------+------------+
| name | subject | sum(score) |
+--------+---------+------------+
| NULL | 语文 | 343 |
| NULL | 数学 | 333 |
| NULL | 英语 | 362 |
| 王海 | NULL | 262 |
| 陶俊 | NULL | 266 |
| 刘可 | NULL | 254 |
| 李春 | NULL | 256 |
+--------+---------+------------+
7 rows in set (Elapsed: 00:00:00.02)
gbase> select name,subject,sum(score) from score group by grouping sets(name,(name,subject));
+--------+---------+------------+
| name | subject | sum(score) |
+--------+---------+------------+
| 王海 | 语文 | 86 |
| 王海 | 数学 | 83 |
| 王海 | 英语 | 93 |
| 陶俊 | 语文 | 88 |
| 陶俊 | 数学 | 84 |
| 陶俊 | 英语 | 94 |
| 刘可 | 语文 | 80 |
| 刘可 | 数学 | 86 |
| 刘可 | 英语 | 88 |
| 李春 | 语文 | 89 |
| 李春 | 数学 | 80 |
| 李春 | 英语 | 87 |
| 王海 | NULL | 262 |
| 陶俊 | NULL | 266 |
| 刘可 | NULL | 254 |
| 李春 | NULL | 256 |
+--------+---------+------------+
16 rows in set (Elapsed: 00:00:00.04)
如上第二个例子中,第一部分是name, 第二部分是(name,subject)两个字段一起。
注意,不考虑重复,也就是你可以写多个name。
gbase> select name,subject,sum(score) from score group by grouping sets(name,name,subject);
+--------+---------+------------+
| name | subject | sum(score) |
+--------+---------+------------+
| NULL | 语文 | 343 |
| NULL | 数学 | 333 |
| NULL | 英语 | 362 |
| 王海 | NULL | 262 |
| 陶俊 | NULL | 266 |
| 刘可 | NULL | 254 |
| 李春 | NULL | 256 |
| 王海 | NULL | 262 |
| 陶俊 | NULL | 266 |
| 刘可 | NULL | 254 |
| 李春 | NULL | 256 |
+--------+---------+------------+
11 rows in set (Elapsed: 00:00:00.03)
边栏推荐
猜你喜欢

Galaxy Kirin system LAN file sharing tutorial

跟我一起AQS SOS AQS

微服务之远程调用

Go from introduction to actual combat - package (notes)

Codeforces Round #717 (Div. 2)

ICML2022 | 可扩展深度高斯马尔可夫随机场

Go from introduction to actual combat - context and task cancellation (notes)

Focus! Tips for installing fonts on domestic computers

Kirin V10 installation font

让马化腾失望了!Web3.0,毫无希望
随机推荐
At 19:00 on Tuesday evening, the 8th live broadcast of battle code Pioneer - how to participate in openharmony's open source contribution in multiple directions
微服务之远程调用
Galaxy Kirin system LAN file sharing tutorial
Serveur mandataire SQUID
Go从入门到实战——Context与任务取消(笔记)
oss上传调用的是哪个方法
SQL必需掌握的100个重要知识点:过滤数据
Bit.Store:熊市漫漫,稳定Staking产品或成主旋律
Ceph分布式存储
Go from introduction to practice - polymorphism (note)
跟我一起AQS SOS AQS
有时间看看ognl表达式
After being forced to develop the app within 20 days, the group was laid off, and the technical director angrily criticized it: I wish "closure as soon as possible!"
图解基于AQS队列实现的CountDownLatch和CyclicBarrier
数组作业题
mysql使用笔记一
行业案例|从零售之王看银行数字化转型的运营之道
Express e stack - small items in array
uniapp拦截请求
Xiao Wang's interview training task