數據庫SQL實戰(牛客網):對所有員工的薪水按照salary進行按照1-N的排名

對所有員工的當前(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;
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章