PostgreSQL 的窗口函数

PostgreSQL 的窗口函数(Window Function)是一种特殊的函数,它允许你对一组行执行计算,这些行与当前行有某种关系,通常是因为它们在某个排序顺序中是相邻的。窗口函数常用于执行如累计总和、移动平均、排名等操作。

以下是 PostgreSQL 中一些常用的窗口函数:

  1. ROW_NUMBER() - 为结果集中的每一行分配一个唯一的序号,通常基于某种顺序。

     

    SELECT ROW_NUMBER() OVER (ORDER BY some_column) FROM some_table;

  2. RANK() - 为结果集中的每一行分配一个排名,排名相同的情况下会导致排名跳过(例如,两个第一,然后是第三个)。

     

    SELECT RANK() OVER (ORDER BY some_column DESC) FROM some_table;

  3. DENSE_RANK() - 与 RANK() 类似,但排名不会跳过(例如,两个第一,然后是第二个)。

     

    SELECT DENSE_RANK() OVER (ORDER BY some_column DESC) FROM some_table;

  4. NTILE(n) - 将结果集分为 n 个大致相等的组,并为每组分配一个从 1 到 n 的数字。

     

    SELECT NTILE(4) OVER (ORDER BY some_column) FROM some_table;

  5. LEAD(column) - 返回当前行的下一行的 column 值。

     

    SELECT LEAD(some_column, 1, default_value) OVER (ORDER BY some_column) FROM some_table;

  6. LAG(column) - 返回当前行的上一行的 column 值。

     

    SELECT LAG(some_column, 1, default_value) OVER (ORDER BY some_column) FROM some_table;

  7. SUM(column) - 计算从当前行到结果集开始的 column 的总和。

     

    SELECT SUM(some_column) OVER (ORDER BY some_column) FROM some_table;

  8. AVG(column) - 计算从当前行到结果集开始的 column 的平均值。

     

    SELECT AVG(some_column) OVER (ORDER BY some_column) FROM some_table;

  9. MIN(column)MAX(column) - 分别计算从当前行到结果集开始或结束的 column 的最小值或最大值。

     

    SELECT MIN(some_column) OVER (ORDER BY some_column), MAX(some_column) OVER (ORDER BY some_column) FROM some_table;

窗口函数使用 OVER 子句来定义窗口的排序和框架(frame)。框架可以是:

  • BETWEEN ... AND ... - 指定一个范围,例如 BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW 表示从结果集的开始到当前行。
  • ROWS 或 RANGE - 指定基于行或基于范围的窗口。

窗口函数非常有用,因为它们允许你在不改变原始表结构的情况下,对数据进行复杂的分析和转换。

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值