SELECT window_func(args) OVER
  ([PARTITION BY col_name, col_name, ...]
   [ORDER BY col_name, col_name, ...]
   [ROWS | RANGE BETWEEN (CURRENT ROW | (UNBOUNDED |[num]) PRECEDING)
  AND (CURRENT ROW | ( UNBOUNDED | [num]) FOLLOWING)]);
   
  • PARTITION BY:可以用一个或多个键分区。和GROUP BY子句类似,PARTITION BY将表按分区键分区,每个分区是一个窗口,窗口函数作用于各个分区。单表分区数最多允许7000个。
  • ORDER BY:决定窗口函数求值的顺序。可以用一个或多个键排序。通过ASC或DESC决定升序或降序。窗口由WINDOW子句指定。如果不指定,默认窗口等同于ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW,即窗口从表或分区(如果OVER子句中用PARTITION BY分区)的初始处到当前行。
  • WINDOW:通过指定一个行区间来定义窗口。
  • CURRENT ROW:表示当前行。
  • num PRECEDING:定义窗口的下限,即窗口从当前行向前数num行处开始。
  • UNBOUNDED PRECEDING:表示窗口没有下限。
  • num FOLLOWING:定义窗口的上限,即窗口从当前行向后数num行处结束。
  • UNBOUNDED FOLLOWING:表示窗口没有上限。
  • ROWS BETWEEN…和RANGE BETWEEN…的区别:
  • ROW为物理窗口,即根据ORDER BY子句排序后,取前N行及后N行的数据计算(与当前行的值无关,只与排序后的行号相关)。
  • RANGE为逻辑窗口,即指定当前行对应值的范围取值,列数不固定,只要行值在范围内,对应列都包含在内。
  • 窗口有以下多种场景,如
  • 窗口只包含当前行。
  •