PostgreSQL的聚集函数

在日常工作中,无论是处理销售数据、分析用户行为,还是统计气象信息,我们常常需要从大量数据中提取关键信息。

在PostgreSQL里,聚集函数就能帮你搞定这些事。它能从多行数据中计算出一个结果,如:

count(计数): 能数出有多少条记录

sum(和) :能算出数值的总和

avg(均值) :能得出平均值

max(最大值) 和 min(最小值):能找出最大值和最小值。

假设查询天气表weather记录城市的最低温度temp_low。

复制代码
SELECT max(temp_lo) FROM weather;

一.WHERE子句进行条件筛选****

WHERE子句的作用是在聚集计算之前筛选出符合条件的行,而聚集函数的结果是在行筛选之后才计算出来的。

复制代码
SELECT city FROM weatherWHERE temp_low = (SELECT max(temp_low) FROM weather);

注意:不能直接在WHERE子句里用max(temp_low)。

二.GROUP BY分组统计

当数据量大且包含多种分类时,GROUP BY子句就派上用场了。

比如,我们想看看每个城市的天气记录数量以及城市的最低温度中最高值,就可以这样写:

​​​​​​​

复制代码
SELECT city, count(*), max(temp_low)FROM weatherGROUP BY city;

把天气表数据按城市分类,然后将分类数据进行统计,显示每个城市有多少条记录,以及每个城市最低温度中的最高值。

还可以用HAVING子句来过滤上面分组后的数据。比如只看每个城市最低温度中最高值小于10的城市,可以在上面语句上加having条件,如下

​​​​​​​

复制代码
SELECT city, count(*), max(temp_low)FROM weatherGROUP BY cityHAVING max(temp_low) < 10;

分类统计之后,再把不符合要求的分类结果去掉。

注意:where和having的区别。where 是在分组和聚集计算之前筛选数据,而having是在分组和聚集计算之后筛选分组。

三.FILTER 精细化聚集控制

PostgreSQL还提供了一个很实用的功能------filter。可以让聚集函数只对符合条件的行进行计算。

比如统计每个城市中最低温度小于10的数量,但又不影响其他聚集函数的计算,可以这样写:

​​​​​​​

复制代码
SELECT city, count(*) FILTER (WHERE temp_low < 10), max(temp_low)FROM weatherGROUP BY city;

为count函数加了一个"过滤器",只即使最低温度小于10的行,而max函数还是对所有记录计算,实现更加灵活的精细化控制。

最后

PostgreSQL的聚集函数是一个强大的工具。通过合理使用WHERE、GROUP BY、HAVING和FILTER,可以精确地控制数据的筛选、分组和统计过程,让数据为我们更好地服务。

掌握这些技巧能让我们在数据处理的道路上更加得心应手。

相关推荐
JIngJaneIL26 分钟前
基于java + vue校园快递物流管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js
廋到被风吹走40 分钟前
【数据库】【MySQL】分库分表策略 分类、优势与短板
数据库·mysql·分类
嘻哈baby1 小时前
Redis高可用部署与集群管理实战
数据库·redis·bootstrap
DolphinDB智臾科技2 小时前
DolphinDB 面向金融交易与定价的统一数据模型
数据库·时序数据库
檀越剑指大厂2 小时前
时序数据库性能之战:金仓数据库如何在复杂场景下反超 InfluxDB?
数据库·时序数据库
计算机毕设VX:Fegn08953 小时前
计算机毕业设计|基于springboot + vue图书借阅管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
数据与人3 小时前
mongodb报错Sort exceeded memory limit of 104857600 bytes
数据库·mongodb
程序员鱼皮3 小时前
消息队列从入门到跑路,保姆级教程!傻子可懂
数据库·程序员·消息队列
C++业余爱好者3 小时前
SQL语言家族入门指南:标准SQL、T-SQL与PL/SQL详解
数据库·sql
白驹过隙^^3 小时前
OB-USP-AGENT安装使用方法
数据库·经验分享·网络协议·tcp/ip·github·ssl