9.21 聚合函数
聚合函数将一组输入返回为单个结果。在表9.55中列出了原生支持的聚合函数。表9.56中列出了统计聚合函数。表9.57中列出了组内有序集聚合函数。表9.58列出了组内假设集函数。表9.59列出了与聚合函数紧密相关的分组操作。有关聚合函数的相关语法,请参见第4.2.7节。更多介绍信息,回顾第2.7节。
对于支持部分模式的聚合函数,可以进行各种有效的优化,例如:并行聚合。
mydb=# select * from weather;
city | temp_lo | temp_hi | prcp | date
---------------+---------+---------+------+------------
San Francisco | 46 | 50 | 0.25 | 1994-11-27
San Francisco | 41 | 55 | 0 | 1994-11-29
San Francisco | 46 | 50 | 0.25 | 1994-11-27
San Francisco | 43 | 57 | 0 | 1994-11-29
Hayward | 37 | 54 | | 1994-11-29
(5 rows)
mydb=# select string_agg(city,',') from weather;
string_agg
-----------------------------------------------------------------
San Francisco,San Francisco,San Francisco,San Francisco,Hayward
(1 row)
mydb=#
表9.56介绍主要用于统计分析的聚合函数。
表9.57的聚合函数使用排序集聚合语法。
表9.58中列出的聚合函数与第9.22节列出的窗口函数相关。
GROUPING示例:
=> SELECT * FROM items_sold;
make | model | sales
-------+-------+-------
Foo | GT | 10
Foo | Tour | 20
Bar | City | 15
Bar | Sport | 5
(4 rows)
=> SELECT make, model, GROUPING(make,model), sum(sales) FROM
items_sold GROUP BY ROLLUP(make,model);
make | model | grouping | sum
-------+-------+----------+-----
Foo | GT | 0 | 10
Foo | Tour | 0 | 20
Bar | City | 0 | 15
Bar | Sport | 0 | 5
Foo | | 1 | 30
Bar | | 1 | 20
| | 3 | 50
(7 rows)