查找入职员工时间排名倒数第三的员工所有信息

查找入职员工时间排名倒数第三的员工所有信息

http://www.nowcoder.com/questionTerminal/ec1ca44c62c14ceb990c3c40def1ec6c

题中说明了“员工入职的日期都不是同一天”,可以直接使用ORDER BY逆序排序,再使用LIMIT和OFFSET确定排名倒数第三的员工

SELECT *
FROM employees
ORDER BY hire_date DESC
LIMIT 1 OFFSET 2

如果有多个员工在同一天入职,可以使用子查询:

SELECT *
FROM employees
WHERE hire_date=
    (SELECT hire_date
    FROM employees
    ORDER BY hire_date DESC
    LIMIT 1 OFFSET 2)

也可以使用窗口函数,对入职时间计算排名序号,使用WHERE条件过滤:

SELECT emp_no,birth_date,first_name,last_name,gender,hire_date
FROM (
    SELECT *,DENSE_RANK() OVER (ORDER BY hire_date DESC) AS r
    FROM employees) AS a
WHERE r=3

这里要注意的是外面的查询不能使用*,因为子查询那里多了一个序号r,所以要把各个字段写出来

全部评论

相关推荐

10-24 13:36
门头沟学院 Java
Zzzzoooo:更新:今天下午有hr联系我去不去客户端,拒了
点赞 评论 收藏
分享
10-09 00:50
已编辑
长江大学 算法工程师
不期而遇的夏天:1.同学你面试评价不错,概率很大,请耐心等待;2.你的排名比较靠前,不要担心,耐心等待;3.问题不大,正在审批,不要着急签其他公司,等等我们!4.预计9月中下旬,安心过节;5.下周会有结果,请耐心等待下;6.可能国庆节前后,一有结果我马上通知你;7.预计10月中旬,再坚持一下;8.正在走流程,就这两天了;9.同学,结果我也不知道,你如果查到了也告诉我一声;10.同学你出线不明朗,建议签其他公司保底!11.同学你找了哪些公司,我也在找工作。
点赞 评论 收藏
分享
4 收藏 评论
分享
牛客网
牛客企业服务