Saltar al contenido principal
Asigna una clasificación a la fila actual dentro de su partición sin dejar huecos. En otras palabras, si el valor de una nueva fila es igual al de una de las filas anteriores, recibirá la siguiente clasificación consecutiva, sin huecos en la numeración. La función rank ofrece el mismo comportamiento, pero con huecos en la clasificación. Sintaxis Alias: denseRank (distingue entre mayúsculas y minúsculas)
dense_rank ()
  OVER ([[PARTITION BY grouping_column] [ORDER BY sorting_column]
        [ROWS or RANGE expression_to_bound_rows_withing_the_group]] | [window_name])
FROM table_name
WINDOW window_name as ([[PARTITION BY grouping_column] [ORDER BY sorting_column])
Para obtener más detalles sobre la sintaxis de las funciones de ventana, consulte: Funciones de ventana - Sintaxis. Valor devuelto
  • Un número para la fila actual dentro de su partición, sin saltos en la clasificación. UInt64.
Ejemplo El siguiente ejemplo se basa en el ejemplo proporcionado en el video explicativo Ranking window functions in ClickHouse.
Query
CREATE TABLE salaries
(
    `team` String,
    `player` String,
    `salary` UInt32,
    `position` String
)
Engine = Memory;

INSERT INTO salaries FORMAT Values
    ('Port Elizabeth Barbarians', 'Gary Chen', 195000, 'F'),
    ('New Coreystad Archdukes', 'Charles Juarez', 190000, 'F'),
    ('Port Elizabeth Barbarians', 'Michael Stanley', 150000, 'D'),
    ('New Coreystad Archdukes', 'Scott Harrison', 150000, 'D'),
    ('Port Elizabeth Barbarians', 'Robert George', 195000, 'M'),
    ('South Hampton Seagulls', 'Douglas Benson', 150000, 'M'),
    ('South Hampton Seagulls', 'James Henderson', 140000, 'M');
Query
SELECT player, salary,
       dense_rank() OVER (ORDER BY salary DESC) AS dense_rank
FROM salaries;
Response
   ┌─player──────────┬─salary─┬─dense_rank─┐
1. │ Gary Chen       │ 195000 │          1 │
2. │ Robert George   │ 195000 │          1 │
3. │ Charles Juarez  │ 190000 │          2 │
4. │ Michael Stanley │ 150000 │          3 │
5. │ Douglas Benson  │ 150000 │          3 │
6. │ Scott Harrison  │ 150000 │          3 │
7. │ James Henderson │ 140000 │          4 │
   └─────────────────┴────────┴────────────┘
Última modificación el 10 de junio de 2026