跳到主要内容

DENSE_RANK

返回一组值中某个值的排名,排名中没有间隔。

排名值从1开始,并按顺序递增。

如果两个值相同,它们具有相同的排名。

语法

DENSE_RANK() OVER ( [ PARTITION BY <expr1> ] ORDER BY <expr2> [ ASC | DESC ] [ <window_frame> ] )

示例

创建表

CREATE TABLE employees (
employee_id INT,
first_name VARCHAR,
last_name VARCHAR,
department VARCHAR,
salary INT
);

插入数据

INSERT INTO employees (employee_id, first_name, last_name, department, salary) VALUES
(1, 'John', 'Doe', 'IT', 90000),
(2, 'Jane', 'Smith', 'HR', 85000),
(3, 'Mike', 'Johnson', 'IT', 82000),
(4, 'Sara', 'Williams', 'Sales', 77000),
(5, 'Tom', 'Brown', 'HR', 75000);

使用 DENSE_RANK 计算每个部门的工资总额

SELECT
department,
SUM(salary) AS total_salary,
DENSE_RANK() OVER (ORDER BY SUM(salary) DESC) AS dense_rank
FROM
employees
GROUP BY
department;

结果:

departmenttotal_salarydense_rank
IT1720001
HR1600002
Sales770003
开始使用 Databend Cloud
低成本
快速分析
多种数据源
弹性扩展
注册