侵权投诉
订阅
纠错
加入自媒体

PG:什么是grouping sets

2022-03-22 11:35
yzsDBA
关注

学习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个聚合。

       原文标题 : PG:什么是grouping sets

声明: 本文由入驻维科号的作者撰写,观点仅代表作者本人,不代表OFweek立场。如有侵权或其他问题,请联系举报。

发表评论

0条评论,0人参与

请输入评论内容...

请输入评论/评论长度6~500个字

您提交的评论过于频繁,请输入验证码继续

暂无评论

暂无评论

    电子工程 猎头职位 更多
    扫码关注公众号
    OFweek电子工程网
    获取更多精彩内容
    文章纠错
    x
    *文字标题:
    *纠错内容:
    联系邮箱:
    *验 证 码:

    粤公网安备 44030502002758号