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

查找在职员工自入职以来的薪水涨幅情况

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

 解题思路:
   第1步:找出最早的入职日期,利用窗口函数
     select  DISTINCT emp_no,
          min(from_date)  over(PARTITION BY emp_no) as 'latest_date'
     from salaries;
   第2步:确定工资涨幅的标志,就是to_date='9999-01-01'
   第3步:连表,涨幅后的工资-入职的工资='growth'
   第4步:别忘了,按涨幅排序。。。。
总的代码:
select s1.emp_no,s3.salary-s1.salary as 'growth'
from salaries as s1
join (
    select  DISTINCT emp_no,
    min(from_date)  over(PARTITION BY emp_no) as 'latest_date'
    from salaries
        ) as s2
on s1.emp_no=s2.emp_no and s1.from_date=s2.latest_date
join salaries as s3
on s1.emp_no=s3.emp_no
where s3.to_date='9999-01-01'
order by s3.salary-s1.salary asc;
全部评论

相关推荐

刷牛客的我很豁达:你是不是对算法有什么误解,你没手握两篇顶刊顶会,还想搞算法岗,有顶刊顶会在算法岗算才入门
点赞 评论 收藏
分享
10-20 15:26
门头沟学院 Java
桥头牛油火锅:这个比例不正常,简历的话项目经历放中间,项目功能分点可以再明确点,前面加“·”或者“1 2 3”,另外简历上的照片可以去外面摄影店拍一下,以后也会用到的,hr筛人也是多少会看的,毕竟世界是一个巨大的卡颜局嘛,还有有些hr由于消息太多可能没看到,后面可能会回来找你,要简历的还会多一点,我也是普2本,比例大致是600:90:15:3,当然我实力不太够,拿的offer比较少,慢慢来吧
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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