学习PG聚合操作机制时,看到ExecInitAgg中初始化时有对AggState中有pergroups等进行初始化[AggState的解释见上一篇:GreenPlum7聚合操作结构体之间关系
那么什么是pergroups呢,它的作用是什么?
ExecInitAgg中:可以看到组数等于组集合数(若没hash的话),每个分组中有numaggs个聚集

这里就需要理解什么是grouping sets。
PostgreSQL9.5版本引入了group by的分组集合功能,提供了GROUPING SETS,CUBE,ROLLUP参数。这些新的标准SQL选项可以让用户在一次查询中生成多个不同级别或者多维度的报表,而不是像以前一样需要几次查询。
postgres=# create table t1(id1 int,name varchar(20),class int,score int);
CREATE TABLE
postgres=# select * from t1; id1 | name | class | score
-----+----------+-------+-------
1 | math | 1 | 50
2 | math | 2 | 90
3 | math | 1 | 70
5 | chinese | 1 | 50
6 | chinese | 2 | 60
4 | chinese | 2 | 60
7 | physical | 1 | 90
8 | physical | 2 | 80
(8 行记录)
首先看下普通的group by:根据name和class字段求和:

可以看到到仅一个聚合分类。那么再看下GROUPING SETS语法:

有3种聚合分类:1)针对name进行分组然后求sum值;2)针对class进行分组,然后求sum值;3)grouping sets种的空,表示所有行都聚合到一个分组中。
需要注意,grouping sets的集合中,一个括号一个分组,如下(name,class)为一个分组。该语句等价于普通的group by。

总结:grouping sets中有一个集合,则有一个聚合;若有2个集合,则2个聚合。
-
SQL
+关注
关注
1文章
789浏览量
46379
发布评论请先 登录
高压放大器的作用是什么呢
DLPC3439的中的3DR引脚的作用是什么?
关于ads1298的右腿驱动部分,有一个右腿驱动参考电压,请问这个参考电压的作用是什么啊,是由什么决定的呢?
ADS4125数据输出口接了缓存器和排阻,这排阻的作用是什么呢?
ADS1298配置寄存器3:RLD_LOFF_SENS位的控制作用是什么呢?
ads1174中的DIN脚的功能说是Daisy-chain,它的作用是什么?
TIDA-00360输出频率50MHz 至 3760MHz有什么作用呢?
安泰:电压放大器原理和作用是什么意思
安泰高压大功率放大器的作用是什么

什么是pergroups呢,它的作用是什么?
评论