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

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

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

注意:可能会存在同一个日期入职的员工,所以入职员工时间排名倒数第三的员工可能不止一个。 这一点很重要,我想到了两种办法,一种是直接使用窗口函数然后取出排名第3的数据,另外一种是对入职日期进行排序去重取第3个数据,然后去原表里面查询。

1.直接使用窗口函数然后取出排名第3的数据

select a.* from employees a join 
  (select emp_no,dense_rank() over(order by hire_date desc) num 
  from employees) b
  on a.emp_no=b.emp_no where b.num=3;

2.对入职日期进行排序去重使用limit取第3个数据,然后去原表里面查询

select * from employees where hire_date=
  (select distinct hire_date from employees order by hire_date desc limit 2,1);
全部评论

相关推荐

08-04 22:37
桂林学院 Java
行不行阿细GO:说真的我现在看到校招java简历都头痛。。千篇一律和阅卷高考作文差不多,估计公司也是吧,到最后就看学历和大厂实习了
投递BOSS直聘等公司10个岗位
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务