【362天】我爱刷题系列121(2018.02.02)

叨叨两句

  1. ~

SQL习题016

1

题目描述
对全部员工的当前(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));数据库

本题的主要思想是复用salaries表进行比较排名,具体思路以下:
一、从两张相同的salaries表(分别为s1与s2)进行对比分析,先将两表限定条件设为to_date = '9999-01-01',挑选出当前全部员工的薪水状况。
二、本题的精髓在于 s1.salary <= s2.salary,意思是在输出s1.salary的状况下,有多少个s2.salary大于等于s1.salary,好比当s1.salary=94409时,有3个s2.salary(分别为94692,94409,94409)大于等于它,但因为94409重复,利用COUNT(DISTINCT s2.salary)去重可得工资为94409的rank等于2。其他排名以此类推。
三、千万不要忘了GROUP BY s1.emp_no,不然输出的记录只有一条(多是第一条或者最后一条,根据不一样的数据库而定),由于用了合计函数COUNT()
四、最后先以 s1.salary 逆序排列,再以 s1.emp_no 顺序排列输出结果


SELECT s1.emp_no, s1.salary, COUNT(DISTINCT s2.salary) AS rank
FROM salaries AS s1, salaries AS s2
WHERE s1.to_date = '9999-01-01'  AND s2.to_date = '9999-01-01' AND s1.salary <= s2.salary
GROUP BY s1.emp_no
ORDER BY s1.salary DESC, s1.emp_no ASC
最后在支持ROW_NUMBER、RANK、DENSE_RANK等函数的SQL Server数据库中,有如下参考代码,惋惜在本题的SQLite数据库中不支持。


SELECT emp_no, salaries, DENSE_RANK() OVER(ORDER BY salary DESC) AS rank
WHERE to_date = '9999-01-01' ORDER BY salary DESC, emp_no ASC
相关文章
相关标签/搜索