数据库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;
发布了292 篇原创文章 · 获赞 73 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/weixin_43777983/article/details/104505260