SQL:窗口函数之OVER()

窗口函数 通用格式 “函数 OVER (PARTITION BY 分组 ORDER BY 排序依据 升降序)”。
这里记录下OVER() 以及搭配LEAD/LAG函数的使用方法(执行平台Impala)

OVER函数

1、不加条件的OVER函数——得到所有的汇总结果

select  day1, sale_money, sum(sale_money) over () as `cum_money`  from t

结果1

2、仅有排序的OVER函数——得到按顺序的累计结果

select  day1, sale_money, sum(sale_money) over (order by day1) as `cum_money`  from t

结果2

3、加分区条件的OVER函数——得到分区的汇总结果

select  day1, sale_money, sum(sale_money) over (partition by month(day1)) as `cum_money`  from t

结果3

4、加分区、排序条件的OVER函数——得到按分区后按顺序的累计结果

select  day1, sale_money, sum(sale_money) over (partition by month(day1) order by day1) as `cum_money`  from t

结果4

5、加窗口大小条件的OVER函数

current row 当前行
n preceding:往前n行
n following:往后n行
unbounded: 起点,对应前面的n

5-1 当前行和前1行

select  day1, sale_money, sum(sale_money) over (order by day1 rows between 1 preceding and current row) as `cum_money`  from t

在这里插入图片描述

5-2 当前行和前面所有行

select  day1, sale_money, sum(sale_money) over (order by day1 rows between unbounded preceding and current row) as `cum_money`  from t

在这里插入图片描述

5-3 当前行和后面所有行

select  day1, sale_money, sum(sale_money) over (order by day1 rows between current row and unbounded following) as `cum_money`  from t

在这里插入图片描述

搭配LEAD/LAG函数

lead(col,n) :往后第n行
lag(col,n) :往前第n行

-- 日期按升序排后,取当前往后的第2条数据
select day1, sale_money, 
       lead(day1,2) over (order by day1 asc) as `后第2行day1`, 
       lead(day1,2) over (order by day1 asc) as `后第2行sale_money`
from t

在这里插入图片描述

-- 日期按升序排后,取当前往前的第2条数据
select day1, sale_money, 
       lag(day1,2) over (order by day1 asc) as `前第2行day1`, 
       lag(day1,2) over (order by day1 asc) as `前第2行sale_money`
from t

在这里插入图片描述

相关推荐

  1. SQL高级:窗口函数

    2024-03-23 06:20:03       63 阅读
  2. SQL-窗口函数合集

    2024-03-23 06:20:03       22 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-23 06:20:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-23 06:20:03       100 阅读
  3. 在Django里面运行非项目文件

    2024-03-23 06:20:03       82 阅读
  4. Python语言-面向对象

    2024-03-23 06:20:03       91 阅读

热门阅读

  1. android AMS的面试题目

    2024-03-23 06:20:03       45 阅读
  2. Flink 架构深度解析

    2024-03-23 06:20:03       41 阅读
  3. webpack proxy工作原理?为什么能解决跨域?

    2024-03-23 06:20:03       46 阅读
  4. 新概念英语1:Lesson7内容详解

    2024-03-23 06:20:03       41 阅读
  5. vim | 安装 vimspector 调试神器

    2024-03-23 06:20:03       41 阅读
  6. C语言-整数与浮点数:内存存储的差异

    2024-03-23 06:20:03       42 阅读
  7. C#面:什么是不可变字符串

    2024-03-23 06:20:03       34 阅读
  8. GO 语言基础学习记录

    2024-03-23 06:20:03       36 阅读
  9. pytorch中的gather函数的定义和作用是什么?

    2024-03-23 06:20:03       45 阅读