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

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

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;
全部评论

相关推荐

牛客刘北:如果暑期实习是27届的话,你要晚一年才会毕业,企业为什么会等你呢?要搞清时间逻辑呀!27届现在实习只能是在暑假实习,这是日常实习,不是暑期实习。所以多去投日常实习吧,暑期实习肯定不会要你的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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