以下是样本数据:
dept_id salary
10 10000
10 20000
10 20000
10 30000
20 50000
20 60000
我想对部门 ID 进行分组,然后按升序生成工资的排名值。输出应如下所示
dept_id 薪资等级
10 10000 1
10 20000 2
10 20000 2
10 30000 3
20 50000 1
20 60000 2
我正在使用以下代码:
set @pk1 ='';
set @rn1 =1;
set @sal ='';
set @val =1;
SELECT dept_id,
salary,
denseRank
FROM
(
SELECT dept_id,
salary,
@rn1 := if(@pk1=dept_id, if(@sal=salary, @rn1, @rn1+@val),1) as denseRank,
@val := if(@pk1=dept_id, if(@sal=salary, @val+1, 1),1) as value,
@pk1 := dept_id,
@sal := salary
FROM
(
SELECT dept_id,
salary
FROM emp
ORDER BY dept_id,salary
) A
) B;
这对于一小部分数据来说效果很好,但是在对整个数据(数千行)运行时变得非常慢并且需要很长时间。是否有更好的方法或一些预定义函数(类似于oracle中的dense_rank()或row_number())来更有效地完成此任务。