前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >PG/GP group by expression语法

PG/GP group by expression语法

作者头像
yzsDBA
发布2022-04-27 15:30:13
5200
发布2022-04-27 15:30:13
举报

GROUP BY在关系数据库中比较常见,他是SQL和PG不可或缺的一个语法。除了可以使用简单字段分组外,还可以使用表达式以更加复杂的方式进行分组。

首先看下简单的GROUP BY语句:

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 1和group by name是相同的,只是语法的不同。

现在看下group by表达式:

没有分组情况下平均值如上所示。还可以使用表达式来动态确定组:

在这种情况下,得到2组,一组大于60的行,一组小于60的行。因此两组的名称为“true”(>60)或“false”(<60)。可以使用任何表达式自行计算这些组。

上面的例子中,我们看下90分和其他分数的人数。不需要再SELECT子句中列出分组条件。当然也可以使用完整的SQL:

再看下执行计划:

另外,HAVING子句中可以使用别名码?

显然是不行的,需要显式使用整个表达式。并且也可以使用不同聚合函数:

这就是group by表达式。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2022-04-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 yanzongshuaiDBA 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档