Partilhar via


rank função de janela de classificação

Aplica-se a:check marked yes Databricks SQL check marked yes Databricks Runtime

Devolve a classificação de um valor em comparação com todos os valores na partição.

Sintaxe

rank()

Argumentos

Esta função não aceita argumentos.

Devoluções

Um INTEGER.

A OVER cláusula da função window deve incluir uma cláusula ORDER BY.

Ao contrário da função dense_rank, a classificação produzirá lacunas na sequência de classificação. Ao contrário row_numberdo , a classificação não quebra laços.

Se a ordem não for exclusiva, as duplicatas compartilham a mesma posição anterior relativa.

Exemplos

> 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