對所有員工的當前(to_date=‘9999-01-01’)薪水按照salary進行按照1-N的排名,相同salary並列且按照emp_no升序排列
CREATE TABLE salaries
(
emp_no
int(11) NOT NULL,
salary
int(11) NOT NULL,
from_date
date NOT NULL,
to_date
date NOT NULL,
PRIMARY KEY (emp_no
,from_date
));
條件中a.salary <= b.salary 可以將所有大於等於a.salary的b.salary列出來,也就是包括自身與其他的大等於自己的薪水列出來
然後根據每個a.salary分組,去重後的b.salary個數count()越大就代表着該數越小,排名越靠後,如果只有自身一個值,就說明自身是最大的,rank也就爲1(count()爲1,因爲前面是大於等於<=,包括自身)。
最後根據薪水值倒排序,相同根據emp_no升序。
select a.emp_no , a.salary , count(distinct b.salary) as rank
from salaries as a,salaries as b
where a.to_date='9999-01-01' and b.to_date='9999-01-01' and a.salary <= b.salary
group by a.emp_no
order by a.salary desc,a.emp_no asc;