共用方式為


row_number 排名 window 函式

適用於:核取記號為「是」Databricks SQL 核取記號為「是」Databricks Runtime

根據 windowpartition中的列順序,為每一列指派唯一的、從 1 開始的序號。

語法

row_number()

引數

函式不接受自變數。

傳回

INTEGER

window 函式的 OVER 子句必須包含 ORDER BY 子句。 與和 rank不同dense_rankrow_number會中斷系結。

如果順序不是唯一的,則結果不具決定性。

範例

> SELECT a,
         b,
         dense_rank() OVER(PARTITION BY a ORDER BY b),
         rank() OVER(PARTITION BY a ORDER BY b),
         row_number() OVER(PARTITION BY a ORDER BY b)
    FROM VALUES ('A1', 2), ('A1', 1), ('A2', 3), ('A1', 1) tab(a, b);
 A1 1   1   1   1
 A1 1   1   1   2
 A1 2   2   3   3
 A2 3   1   1   1