【sql高级】postgresql之窗口函数用法

1. 背景

窗口函数在在SQL中是非常有用的工具,特别是在需要对查询结果进行分析、排名、聚合或者对结果进行一些特定的计算时。以下是一些常见的场景:

  1. 排名和分组:窗口函数可以轻松地对结果集进行排名、分组和分区。例如,你可以使用 ROW_NUMBER()、RANK()、DENSE_RANK() 等函数来为每一行分配一个排名值,而不需要对查询结果进行额外的子查询或者连接操作。

  2. 移动平均和累计求和:窗口函数可以用来计算移动平均、累计求和或者其他一些基于窗口的聚合函数。这种功能对于时间序列分析或者趋势分析非常有用。

  3. Top N 查询:通过使用窗口函数,你可以很容易地实现Top N查询,即获取每个分组或者分区中前N个值。这在很多业务场景下都是非常有用的,比如获取每个类别的前几名产品。

  4. 比较当前行和前/后行:有些情况下,你可能需要比较当前行和前一行或者后一行的数据。窗口函数可以帮助你实现这样的需求,比如计算当前行与上一行的差值或者比率等。

  5. 处理重叠区间:在处理时间区间或者其他类型的重叠区间时,窗口函数可以帮助你轻松地识别和处理这些重叠的区间。

  6. 执行复杂的聚合操作:有时候,你可能需要对聚合操作的结果进行更复杂的处理,比如计算每个分组内的平均值,然后将每个值与该分组内的所有值进行比较。窗口函数可以帮助你在不增加额外的查询复杂度的情况下实现这些功能。

2. 使用举例

dim.dim_mltt_trading_sequence_i表中有如下数据:

使用窗口函数 ROW_NUMBER() 可以对sequence_id、unit_id、center_id这三个字段相同的数据进行排序(按id排序)

使用的sql如下:

sql 复制代码
select
    t7.*,
    ROW_NUMBER() OVER (PARTITION BY t7.sequence_id,
        t7.unit_id, t7.center_id ORDER BY t7.id) as rn
from
        dim.dim_mltt_trading_sequence_i t7;

输出结果如下:

相关推荐
廿一夏1 小时前
MySql存储引擎与索引
数据库·sql·mysql
lzhdim3 小时前
SQL 入门 15:SQL 事务:从 ACID 到四种常见的并发问题
数据库·sql
瀚高PG实验室4 小时前
瀚高企业版V9.1.1在pg_restore还原备份文件时提示extract函数语法问题
数据库·瀚高数据库
TDengine (老段)4 小时前
TDengine Tag 设计哲学与 Schema 变更机制
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
YOU OU5 小时前
Spring IoC&DI
java·数据库·spring
Muscleheng6 小时前
Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错
数据库·postgresql
罗超驿7 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试
jran-7 小时前
Redis 命令
数据库·redis·缓存
小江的记录本7 小时前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven
June`8 小时前
多线程redis下如何解决aof重写和rdb持久化的数据一致性问题
数据库·redis·缓存